.kernels-educational{height:100%;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;color:#e0e0e0;padding:0}.edu-main-area{flex:1;display:flex;flex-direction:row;min-height:0;overflow:hidden}.edu-left-section{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.edu-images-area{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.5rem;padding:.5rem 1rem;min-height:0}.edu-matrices-panel{width:380px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem;background:#ffffff0d;padding:1rem;overflow-y:auto;justify-content:flex-start}.grid-container{text-align:center;display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;max-width:45%}.grid-container h3{margin:0 0 .5rem;font-size:1.1rem;color:#fff;font-weight:600}.pixel-grid-wrapper{width:100%;aspect-ratio:1;max-height:calc(100vh - 140px);display:flex;align-items:center;justify-content:center;background:#1a1a2a;border-radius:6px;border:2px solid #333}.pixel-grid{display:grid;gap:1px;background:#222;padding:1px;border-radius:4px;box-shadow:0 2px 8px #0006}.pixel-cell{transition:outline .1s,border .1s;position:relative;box-sizing:border-box;border:1px solid transparent}.pixel-cell.empty{background:#000!important}.pixel-cell.highlighted{border-color:#ffd70080;z-index:1}.pixel-cell.highlighted.kernel-top{border-top:3px solid #ffd700}.pixel-cell.highlighted.kernel-bottom{border-bottom:3px solid #ffd700}.pixel-cell.highlighted.kernel-left{border-left:3px solid #ffd700}.pixel-cell.highlighted.kernel-right{border-right:3px solid #ffd700}.pixel-cell.center{outline:3px solid #ff4444;z-index:2}.pixel-cell:hover{outline:2px solid #00d4ff;z-index:3}.kernel-display{background:#ffffff14;padding:1rem;border-radius:8px;text-align:center}.kernel-display h3{margin:0 0 .4rem;font-size:1.2rem;color:#fff;font-weight:600}.kernel-display .kernel-desc{font-size:.85rem;color:#aaa;margin:0 0 .75rem;line-height:1.3}.kernel-with-fraction{display:flex;align-items:center;justify-content:center;gap:.5rem}.kernel-fraction{font-size:1.5rem;color:#aaa}.kernel-matrix-edu{display:inline-flex;flex-direction:column;gap:2px;background:#222;padding:4px;border-radius:6px}.kernel-matrix-edu .kernel-row{display:flex;gap:2px}.kernel-matrix-edu .kernel-cell{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;border-radius:4px}.kernel-matrix-edu.size-5 .kernel-cell{width:34px;height:34px;font-size:.85rem}.kernel-matrix-edu.size-6 .kernel-cell{width:28px;height:28px;font-size:.75rem}.kernel-matrix-edu .kernel-cell.positive{background:#2e7d32;color:#c8e6c9}.kernel-matrix-edu .kernel-cell.negative{background:#c62828;color:#ffcdd2}.kernel-matrix-edu .kernel-cell.zero{background:#424242;color:#999}.kernel-display .scale-note{font-size:1rem;color:#888;margin:.5rem 0 0}.calc-info{background:#ffffff14;padding:1rem;border-radius:8px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.calc-info h4{margin:0;font-size:1.1rem;color:#00d4ff;font-weight:600}.calc-info .calc-label{font-size:.85rem;color:#aaa;margin-bottom:.3rem}.calc-info .mini-matrix{display:flex;flex-direction:column;gap:2px;background:#222;padding:3px;border-radius:4px}.calc-info .mini-row{display:flex;gap:2px}.calc-info .mini-cell{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;border-radius:3px}.calc-info.size-5 .mini-cell{width:30px;height:30px;font-size:.75rem}.calc-info.size-6 .mini-cell{width:26px;height:26px;font-size:.65rem}.calc-info .calc-equals{font-size:1.5rem;color:#666;font-weight:700}.calc-info .result-pixel{width:50px;height:50px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 2px 8px #0006}.pixel-info-row{text-align:center;padding:.3rem .5rem;font-family:monospace;font-size:.9rem;color:#00d4ff;min-height:1.5rem}.pixel-info-row .hint{color:#666;font-style:italic;font-family:inherit}.edu-controls-bar{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:1rem;padding:.4rem .75rem;background:#ffffff0d;border-top:1px solid #333;flex-wrap:wrap}.edu-controls-bar .control-group{display:flex;flex-direction:row;align-items:center;gap:.4rem}.edu-controls-bar .control-group label{font-weight:500;color:#ccc;font-size:.85rem;white-space:nowrap}.edu-controls-bar select{padding:.25rem .5rem;border:1px solid #555;border-radius:4px;font-size:.85rem;background:#2a2a3a;color:#e0e0e0;min-width:100px}.edu-controls-bar select:focus{outline:none;border-color:#00d4ff}.edu-controls-bar input[type=range]{width:70px;accent-color:#00d4ff}.edu-animation-controls{display:flex;gap:.3rem}.edu-animation-controls button{padding:.3rem .5rem;border:none;border-radius:5px;font-size:.95rem;cursor:pointer;transition:all .2s;font-weight:500;min-width:36px}.edu-animation-controls button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 3px 10px #0000004d}.edu-animation-controls button:disabled{opacity:.5;cursor:not-allowed}.edu-animation-controls button.play{background:#4caf50;color:#fff}.edu-animation-controls button.stop{background:#f44336;color:#fff}.edu-animation-controls button:not(.play):not(.stop){background:#2196f3;color:#fff}@media (max-width: 1000px){.edu-main-area{flex-direction:column}.edu-matrices-panel{width:100%;flex-direction:row;justify-content:center;gap:1rem;padding:.5rem;max-height:150px}.kernel-display,.calc-info{flex:1;max-width:300px}.grid-container{max-width:none}.pixel-grid-wrapper{max-height:calc(100vh - 300px)}}.animation-controls{display:flex;flex-direction:column;gap:.5rem}.animation-controls.layout-horizontal{flex-direction:row;align-items:center}.animation-controls.layout-compact{flex-direction:row;align-items:center;gap:.25rem}.animation-controls-buttons{display:flex;gap:.25rem;align-items:center}.anim-btn{display:flex;align-items:center;justify-content:center;border:none;background:#ffffff1a;color:#fff;border-radius:4px;cursor:pointer;transition:all .15s ease;font-size:1rem;padding:.4rem .6rem;min-width:2rem}.anim-btn:hover:not(:disabled){background:#fff3}.anim-btn:disabled{opacity:.4;cursor:not-allowed}.anim-btn.play-pause{background:linear-gradient(135deg,#00d9ff,#6366f1);min-width:2.5rem;font-size:1.1rem}.anim-btn.play-pause:hover:not(:disabled){background:linear-gradient(135deg,#00e5ff,#7c7fff);box-shadow:0 0 10px #00d9ff66}.anim-btn.play-pause.playing{background:linear-gradient(135deg,#ff6b9d,#f97316)}.anim-btn.reset{background:#ef444433;color:#f87171}.anim-btn.reset:hover:not(:disabled){background:#ef44444d}.anim-btn.complete{background:#22c55e33;color:#4ade80}.anim-btn.complete:hover:not(:disabled){background:#22c55e4d}.animation-controls.size-small .anim-btn{font-size:.85rem;padding:.3rem .4rem;min-width:1.5rem}.animation-controls.size-small .anim-btn.play-pause{min-width:2rem;font-size:.9rem}.animation-controls.size-large .anim-btn{font-size:1.25rem;padding:.5rem .8rem;min-width:2.5rem}.animation-controls.size-large .anim-btn.play-pause{min-width:3rem;font-size:1.4rem}.animation-controls-slider{display:flex;align-items:center;gap:.5rem;flex:1;min-width:100px}.animation-controls-slider input[type=range]{flex:1;height:6px;border-radius:3px;background:#ffffff1a;-webkit-appearance:none;-moz-appearance:none;appearance:none}.animation-controls-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#00d9ff;cursor:pointer;box-shadow:0 0 5px #00d9ff80}.animation-controls-slider .position-label{font-size:.75rem;color:#ffffffb3;min-width:4rem;text-align:center}.speed-control{display:flex;align-items:center;gap:.5rem}.speed-control label{font-size:.85rem;color:#fffc}.speed-control input[type=range]{width:80px;height:4px;border-radius:2px;background:#ffffff1a;-webkit-appearance:none;-moz-appearance:none;appearance:none}.speed-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#a78bfa;cursor:pointer}.frame-by-frame-toggle{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.85rem;color:#fffc}.frame-by-frame-toggle input[type=checkbox]{accent-color:#00d9ff}.animation-controls-compact{display:flex;gap:.25rem;align-items:center}.animation-controls-compact button{display:flex;align-items:center;justify-content:center;border:none;background:#ffffff1a;color:#fff;border-radius:4px;cursor:pointer;padding:.3rem .5rem;font-size:.9rem;transition:all .15s ease}.animation-controls-compact button:hover:not(:disabled){background:#fff3}.animation-controls-compact button:disabled{opacity:.4;cursor:not-allowed}.animation-controls-compact button.playing{background:linear-gradient(135deg,#ff6b9d,#f97316)}.mallat-unified{display:flex;gap:20px;height:100%;padding:10px;box-sizing:border-box}.mallat-unified.compact{padding:5px;gap:10px}.mallat-main{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0}.mode-tabs{display:flex;gap:5px}.mode-tab{flex:1;padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#888;font-size:.85rem;cursor:pointer;transition:all .2s}.mode-tab:hover{background:#ffffff1a;color:#aaa}.mode-tab.active{background:#00d4ff26;border-color:#00d4ff;color:#00d4ff}.canvas-container{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;overflow:hidden}.canvas-container.edu-mode .mallat-canvas-wrapper{width:100%;max-width:900px;aspect-ratio:900 / 580}.canvas-container.full-mode .mallat-canvas-wrapper{width:100%;max-width:600px;aspect-ratio:550 / 400}.mallat-canvas-wrapper{position:relative;max-height:100%}.canvas-container canvas{border-radius:8px;box-shadow:0 2px 10px #0000004d;width:100%;height:100%}.step-info-overlay{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:10;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px;padding:10px 20px;background:#000000d9;border-radius:8px;border:1px solid rgba(255,215,0,.4)}.step-info-overlay .step-number{font-size:.75rem;color:#888;text-transform:uppercase;letter-spacing:1px}.step-info-overlay .step-title{font-size:1rem;font-weight:700;color:gold}.step-info-overlay .step-desc{font-size:.85rem;color:#aaa}.highlight-info-overlay{position:absolute;top:8px;left:50%;transform:translate(-50%);padding:6px 14px;background:#000000b3;border-radius:6px;font-weight:700;font-size:.9rem}.annotation-overlay{position:absolute;top:0;left:50%;transform:translate(-50%);pointer-events:none;overflow:visible}.annotation-overlay text{font-family:system-ui,sans-serif}.annotation-overlay .step-label{fill:gold;font-size:13px;font-weight:700}.annotation-overlay .step-desc{fill:#aaa;font-size:11px}.annotation-overlay .highlight-label{font-size:13px;font-weight:700}.edu-controls{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#ffffff08;border-radius:8px}.edu-controls .animation-controls{flex-shrink:0}.edu-controls .animation-controls-buttons{gap:6px}.edu-controls .anim-btn{width:36px;height:36px;min-width:36px;font-size:1rem}.edu-controls .anim-btn.play-pause{width:40px;height:40px;min-width:40px;font-size:1.1rem}.ctrl-btn{width:36px;height:36px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#ccc;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.ctrl-btn:hover:not(:disabled){background:#ffffff1a;border-color:#00d4ff}.ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.ctrl-btn.play{background:#00c86433;border-color:#00c864}.ctrl-btn.stop{background:#ff646433;border-color:#ff6464}.step-dots{display:flex;gap:6px;margin-left:auto}.step-dots .dot{width:10px;height:10px;border-radius:50%;background:#fff3;cursor:pointer;transition:all .2s}.step-dots .dot:hover{background:#fff6}.step-dots .dot.done{background:#00d4ff80}.step-dots .dot.active{background:gold;transform:scale(1.3)}.energy-section{padding:10px;background:#ffffff08;border-radius:8px}.energy-bar{display:flex;height:24px;border-radius:4px;overflow:hidden;background:#0000004d}.energy-segment{display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#000;cursor:pointer;transition:all .2s;min-width:0}.energy-segment:hover,.energy-segment.highlight{filter:brightness(1.2);box-shadow:inset 0 0 0 2px #fff}.energy-note{margin:8px 0 0;font-size:.75rem;color:#888;text-align:center}.mallat-sidebar{width:580px;display:flex;flex-direction:column;gap:10px;flex-shrink:0;overflow:visible}.sidebar-section{background:#ffffff08;padding:14px 20px;border-radius:10px;width:100%;flex-shrink:0}.sidebar-section label{display:block;font-size:1.1rem;color:#aaa;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.sidebar-section select,.sidebar-section input[type=range]{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;padding:10px 12px;font-size:1.1rem}.sidebar-section select{cursor:pointer}.sidebar-section input[type=range]{padding:0;height:6px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.sidebar-section input[type=range]::-webkit-slider-thumb{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;background:#00d4ff;border-radius:50%;cursor:pointer}.source-tabs{display:flex;gap:8px;margin-bottom:8px;width:100%}.source-tabs button{flex:1 1 0;padding:10px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#888;font-size:1.1rem;cursor:pointer;transition:all .2s;white-space:nowrap;min-width:0}.source-tabs button:hover{background:#ffffff1a}.source-tabs button.active{background:#00d4ff26;border-color:#00d4ff;color:#00d4ff}.band-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.band-buttons button{padding:6px 4px;background:transparent;border:2px solid;border-radius:4px;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .2s}.band-buttons button:hover{filter:brightness(1.2)}.band-buttons button.active{background:currentColor;color:#fff!important}.sidebar-legend{background:#ffffff08;padding:14px 20px;border-radius:10px;width:100%}.sidebar-legend h4{margin:0 0 8px;font-size:1rem;color:#ccc}.legend-item{display:inline-flex;align-items:center;gap:8px;font-size:1rem;color:#bbb;margin-right:16px;margin-bottom:4px}.legend-item .color-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-item strong{color:#ccc}.sidebar-formula{background:#ffffff08;padding:14px 20px;border-radius:10px;width:100%}.sidebar-formula h4{margin:0 0 8px;font-size:1rem;color:#ccc}.sidebar-formula .katex{font-size:1.1rem;color:#ddd;display:block;margin:6px 0}.formula-item{display:flex;align-items:center;gap:8px;margin:4px 0}.formula-item .filter-name{font-size:.75rem;color:#888;min-width:50px}.formula-note{margin:10px 0 0;font-size:.9rem;color:#888;font-style:italic}.sidebar-tree{background:#ffffff08;padding:14px 20px;border-radius:10px;width:100%}.sidebar-tree h4{margin:0 0 8px;font-size:.95rem;color:#aaa}.tree-diagram{display:flex;flex-direction:column;align-items:center;gap:6px}.tree-node{padding:4px 10px;background:#00d4ff26;border:1px solid #00d4ff;border-radius:4px;font-size:.75rem;font-weight:700;color:#00d4ff}.tree-node.root{background:#ffffff1a;border-color:#fff;color:#fff}.tree-node.l-node{background:#00d4ff1a;border-color:#00d4ff;color:#00d4ff}.tree-node.h-node{background:#ffd7001a;border-color:gold;color:gold}.tree-level{display:flex;gap:12px}.tree-branch{display:flex;flex-direction:column;align-items:center;gap:4px}.branch-label{font-size:.65rem;color:#fa0;font-weight:700}.tree-sublevel{display:flex;gap:4px}.tree-leaf{padding:3px 6px;background:#0000004d;border:2px solid;border-radius:3px;font-size:.7rem;font-weight:700;color:inherit}.tree-leaf.ll{color:#00d4ff}.tree-leaf.lh{color:#ff9f43}.tree-leaf.hl{color:#c9b1ff}.tree-leaf.hh{color:#ff6b9d}.mallat-unified.compact .mallat-sidebar{width:280px}.mallat-unified.compact .mode-tab{padding:6px 8px;font-size:.8rem}.mallat-unified.compact .ctrl-btn{width:32px;height:32px}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:1rem;color:#ccc}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#00d4ff}.heatmap-legend{display:flex;justify-content:space-between;margin-top:8px;padding:6px 8px;background:#0000004d;border-radius:4px;font-size:.7rem}.heatmap-legend .hl-pos{color:#00c864}.heatmap-legend .hl-zero{color:#666}.heatmap-legend .hl-neg{color:#dc3545}.wavelet-scan-demo{display:flex;flex-direction:column;width:100%;height:100%;box-sizing:border-box;overflow:hidden}.wavelet-scan-demo .scan-top-row{flex:1;display:flex;gap:.75rem;padding:.5rem;min-height:0}.wavelet-scan-demo .scan-main{flex:1;display:flex;flex-direction:column;gap:.5rem;min-width:0}.wavelet-scan-demo .scan-plot-section{flex:1;display:flex;flex-direction:column;min-height:0}.wavelet-scan-demo .scan-plot-section.result{flex:.7}.wavelet-scan-demo .plot-label{text-align:center;padding:.3rem .5rem;background:#ffffff0d;border-radius:6px 6px 0 0;font-size:1rem}.wavelet-scan-demo .plot-label.clean{display:flex;justify-content:center;gap:1.5rem;padding:.4rem 1rem;font-size:1rem;font-weight:500}.wavelet-scan-demo .plot-label .label-signal{color:#88a;position:relative;padding-left:16px}.wavelet-scan-demo .plot-label .label-signal:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:12px;height:2px;background:#88a;border-radius:1px}.wavelet-scan-demo .plot-label .label-wavelet{position:relative;padding-left:16px}.wavelet-scan-demo .plot-label .label-wavelet:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:12px;height:3px;background:currentColor;border-radius:1px}.wavelet-scan-demo .plot-label .label-result{color:#bd93f9;font-weight:600}.wavelet-scan-demo .scan-canvas-container{flex:1;background:#050510;border-radius:0 0 8px 8px;overflow:hidden}.wavelet-scan-demo .scan-canvas-container canvas{display:block;width:100%;height:100%}.wavelet-scan-demo .scan-sidebar{width:300px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;gap:.75rem;overflow:hidden}.wavelet-scan-demo .scan-section{background:#ffffff0d;border-radius:8px;overflow:hidden}.wavelet-scan-demo .scan-section.explanation{background:#ffffff08}.wavelet-scan-demo .scan-section-header{padding:.6rem .8rem;background:#ffffff0d;font-weight:600;font-size:1.05rem;color:#fff}.wavelet-scan-demo .scan-section-content{padding:.7rem .8rem}.wavelet-scan-demo .scan-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.wavelet-scan-demo .scan-btn{padding:.6rem;border:2px solid transparent;border-radius:6px;background:#ffffff14;color:#aaa;font-size:1rem;cursor:pointer;transition:all .15s}.wavelet-scan-demo .scan-btn:hover{background:#ffffff1f}.wavelet-scan-demo .scan-btn.active{background:#ffffff26;border-color:#00d9ff;color:#fff;font-weight:600}.wavelet-scan-demo .scan-desc{font-size:.85rem;color:#aaa;margin:0;line-height:1.4}.wavelet-scan-demo .scan-section.coefficient-display{background:linear-gradient(135deg,#00d9ff14,#bd93f914);border:1px solid rgba(0,217,255,.2)}.wavelet-scan-demo .scan-section.coefficient-display .scan-section-content{padding:.75rem;text-align:center}.wavelet-scan-demo .scan-section.coefficient-display .coef-value{font-size:1.2rem;font-weight:600}.wavelet-scan-demo .scan-section.explanation p{font-size:.95rem;color:#bbb;margin:.3rem 0;line-height:1.5}.wavelet-scan-demo .scan-section.explanation strong{font-size:1.1rem}.wavelet-scan-demo .scan-controls-bar{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.25rem;padding:.5rem 1rem;background:#ffffff0d;border-top:1px solid #333;flex-wrap:wrap}.wavelet-scan-demo .scan-control-group{display:flex;flex-direction:row;align-items:center;gap:.5rem}.wavelet-scan-demo .scan-control-group label{font-size:.9rem;color:#ccc;white-space:nowrap}.wavelet-scan-demo .scan-control-group input[type=range]{width:90px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff26;border-radius:3px;outline:none}.wavelet-scan-demo .scan-control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#00d9ff;border-radius:50%;cursor:pointer}.wavelet-scan-demo .scan-checkbox-control{display:flex;align-items:center;gap:.4rem;font-size:.9rem;color:#aaa;cursor:pointer}.wavelet-scan-demo .scan-checkbox-control input[type=checkbox]{accent-color:#00d9ff;width:16px;height:16px}.wavelet-scan-demo .scan-anim-controls{display:flex;gap:.4rem}.wavelet-scan-demo .scan-anim-btn{padding:.4rem .65rem;border:none;border-radius:5px;font-size:1rem;cursor:pointer;transition:all .15s}.wavelet-scan-demo .scan-anim-btn.play{background:#00d9ff;color:#000}.wavelet-scan-demo .scan-anim-btn.play:hover{background:#00c4e8}.wavelet-scan-demo .scan-anim-btn.stop{background:#ff6b6b;color:#fff}.wavelet-scan-demo .scan-anim-btn.stop:hover{background:#ff5252}.wavelet-scan-demo .scan-anim-btn.step{background:#2196f3;color:#fff}.wavelet-scan-demo .scan-anim-btn.reset{background:#ffffff1a;color:#aaa}.wavelet-scan-demo .scan-anim-btn.reset:hover{background:#ffffff26;color:#fff}.mallat-1d-edu{display:flex;width:100%;height:100%;gap:1rem;padding:.5rem;box-sizing:border-box}.mallat-1d-edu.compact{padding:.25rem}.mallat-1d-main{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.mallat-1d-header{text-align:center}.mallat-1d-header h3{margin:0 0 .6rem;color:gold;font-size:1.5rem}.mallat-formula{background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:8px;padding:.5rem 1rem;display:inline-block}.mallat-1d-canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:#0a0a1a;border-radius:8px;overflow:hidden;min-height:400px;border:1px solid rgba(255,255,255,.1)}.mallat-1d-canvas-wrapper{position:relative;width:100%;height:100%;max-width:850px;aspect-ratio:750 / 620}.mallat-1d-canvas-wrapper canvas{width:100%;height:100%}.canvas-labels{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;padding:0 20px}.canvas-labels .signal-label{position:absolute;left:20px;font-size:15px;font-weight:700}.canvas-labels .signal-label span{font-weight:400;font-size:13px}.canvas-labels .filter-label{position:absolute;left:20px;right:20px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-labels .graph-info{position:absolute;left:20px;right:20px;font-size:13px;white-space:nowrap}.canvas-labels .formulas-container{position:absolute;left:20px;right:20px;display:flex;flex-direction:column;gap:4px;font-size:12px}.canvas-labels .formula-line{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap}.canvas-labels .status-label{position:absolute;left:35px;right:35px;font-size:14px;font-weight:700;color:#fff;text-align:center}.mallat-1d-controls{display:flex;justify-content:center;gap:.75rem;padding:.5rem}.mallat-1d-controls .animation-controls,.mallat-1d-controls .animation-controls-buttons{gap:.5rem}.mallat-1d-controls .anim-btn{padding:.8rem 1.5rem;min-width:48px;font-size:1.2rem}.mallat-1d-controls .anim-btn.play-pause{min-width:56px}.mallat-1d-controls .ctrl-btn{padding:1rem 2rem;border:none;border-radius:6px;font-size:1.1rem;cursor:pointer;transition:all .2s;min-width:120px;line-height:1.2;overflow:hidden}.mallat-1d-controls .ctrl-btn.play{background:linear-gradient(135deg,#00d4ff,#00a0cc);color:#fff}.mallat-1d-controls .ctrl-btn.stop{background:linear-gradient(135deg,#ff6b9d,#c47);color:#fff}.mallat-1d-controls .ctrl-btn.step{background:#ffd70033;color:gold;border:1px solid rgba(255,215,0,.4)}.mallat-1d-controls .ctrl-btn.back{background:#00d4ff33;color:#00d4ff;border:1px solid rgba(0,212,255,.4)}.mallat-1d-controls .ctrl-btn.reset{background:#88a3;color:#88a;border:1px solid rgba(136,136,170,.4)}.mallat-1d-controls .ctrl-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.mallat-1d-controls .ctrl-btn:disabled{opacity:.5;cursor:not-allowed}.mallat-1d-input-controls{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;padding:.75rem 1rem;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.08);margin-top:.5rem}.mallat-1d-input-controls .input-group{display:flex;align-items:center;gap:.5rem}.mallat-1d-input-controls .input-group label{font-size:.95rem;color:#aaa;white-space:nowrap}.mallat-1d-input-controls .input-group select{padding:.4rem .6rem;background:#0006;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:.9rem;cursor:pointer}.mallat-1d-input-controls .input-group select:focus{outline:none;border-color:gold}.mallat-1d-input-controls .input-group input[type=range]{width:80px;cursor:pointer}.mallat-1d-input-controls .input-group.checkboxes{display:flex;gap:1rem}.mallat-1d-input-controls .checkbox-label{display:flex;align-items:center;gap:.3rem;font-size:.9rem;color:#aaa;cursor:pointer}.mallat-1d-input-controls .checkbox-label:hover{color:#fff}.mallat-1d-input-controls .checkbox-label input{cursor:pointer}.mallat-1d-sidebar{width:fit-content;max-width:540px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;gap:1rem;background:#ffffff05;border-radius:8px;padding:1.25rem;overflow-y:auto}.mallat-1d-sidebar .sidebar-section{display:flex;flex-direction:column;gap:.4rem}.mallat-1d-sidebar label{font-size:1rem;color:#aaa;font-weight:500}.mallat-1d-sidebar select,.mallat-1d-sidebar input[type=range]{width:100%;padding:.5rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#fff;font-size:1rem}.mallat-1d-sidebar select:focus{outline:none;border-color:gold}.mallat-1d-sidebar small{color:#666;font-size:.9rem}.mallat-1d-sidebar .checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.mallat-1d-sidebar .checkbox-label input{width:auto}.sidebar-info{padding:1.25rem;background:#ffd7000d;border-radius:8px;border:1px solid rgba(255,215,0,.2)}.sidebar-info+.sidebar-info{margin-top:0}.sidebar-info h4{margin:0 0 .75rem;color:gold;font-size:1.7rem}.sidebar-info p{margin:.4rem 0;font-size:1.45rem;color:#ccc;line-height:1.5}.mallat-1d-edu.compact .mallat-1d-header h3{font-size:1rem}.mallat-1d-edu.compact .mallat-1d-sidebar{width:fit-content;max-width:540px}.mallat-1d-edu.compact .mallat-formula{font-size:.9rem;padding:.3rem .6rem}.mallat-1d-edu.compact .mallat-1d-input-controls{gap:1rem;padding:.5rem}.filter-bank-view{display:flex;gap:1.5rem;height:100%;padding:.5rem;background:var(--bg-dark, #0a0a1a)}.filter-bank-view.compact{padding:.25rem;gap:1rem}.filter-bank-main{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.filter-bank-tabs{display:flex;gap:.5rem;padding:0 .5rem}.filter-bank-tabs button{flex:1;padding:.6rem .8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-bank-tabs button:hover{background:#ffffff1a;color:#aaa}.filter-bank-tabs button.active{background:linear-gradient(135deg,#ffd70026,#ffaa001a);border-color:#ffd70066;color:gold}.filter-bank-canvas-container{flex:1;display:flex;justify-content:center;align-items:center;background:#0a0a1e80;border-radius:12px;padding:1rem;min-height:300px}.filter-bank-canvas-container canvas{max-width:100%;max-height:100%;border-radius:8px}.filter-bank-controls{display:flex;justify-content:center;gap:.75rem;padding:.5rem}.filter-bank-controls .ctrl-btn{padding:.5rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ccc;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem}.filter-bank-controls .ctrl-btn:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40}.filter-bank-controls .ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.filter-bank-controls .ctrl-btn.play{background:#00ff8826;border-color:#00ff884d;color:#0f8}.filter-bank-controls .ctrl-btn.play:hover:not(:disabled){background:#00ff8840}.filter-bank-controls .ctrl-btn.stop{background:#ff6b9d26;border-color:#ff6b9d4d;color:#ff6b9d}.filter-bank-options{display:flex;justify-content:center;gap:1.5rem;padding:.5rem}.filter-bank-options .option-group{display:flex;align-items:center;gap:.5rem}.filter-bank-options label{color:#888;font-size:.8rem}.filter-bank-options select{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.4rem .6rem;color:#ddd;font-size:.8rem;cursor:pointer}.filter-bank-options select:hover{border-color:#ffffff40}.filter-bank-sidebar{width:280px;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;overflow-y:auto}.filter-bank-view.compact .filter-bank-sidebar{width:240px}.fb-sidebar-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.75rem}.fb-sidebar-section h4{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:gold;display:flex;align-items:center;gap:.4rem}.fb-sidebar-section p{margin:.3rem 0;font-size:.8rem;color:#aaa;line-height:1.4}.fb-sidebar-section strong{color:#fff}.filter-coefs{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.filter-coef-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;background:#0003;border-radius:6px}.filter-coef-row .filter-name{font-weight:600;font-size:.8rem;min-width:40px}.filter-coef-row .filter-name.lp{color:#0f8}.filter-coef-row .filter-name.hp{color:#ff6b9d}.filter-coef-row .filter-values{font-family:JetBrains Mono,monospace;font-size:.7rem;color:#888}.qmf-formula{background:#ffd7000d;border:1px solid rgba(255,215,0,.15);border-radius:8px;padding:.6rem;text-align:center}.qmf-formula .katex{font-size:.85rem}.step-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;background:#ffaa001a;border-radius:8px;margin-top:.5rem}.step-indicator .step-num{font-weight:700;color:#fa0;font-size:.9rem}.step-indicator .step-desc{color:#ddd;font-size:.8rem}.color-analysis{color:#00d4ff}.color-synthesis{color:#ff9f43}.color-lowpass{color:#0f8}.color-highpass{color:#ff6b9d}.highlight-box{padding:.5rem;border-radius:6px;margin-top:.5rem}.highlight-box.analysis{background:#00d4ff14;border-left:3px solid #00d4ff}.highlight-box.synthesis{background:#ff9f4314;border-left:3px solid #ff9f43}.highlight-box.perfect{background:#00ff8814;border-left:3px solid #00ff88}@media (max-width: 1200px){.filter-bank-sidebar{width:220px}}@media (max-width: 900px){.filter-bank-view{flex-direction:column}.filter-bank-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.fb-sidebar-section{flex:1;min-width:200px}}.pyramid-decomp-view{display:flex;gap:1.5rem;height:100%;padding:.5rem;background:var(--bg-dark, #0a0a1a)}.pyramid-decomp-view.compact{padding:.25rem;gap:1rem}.pyramid-main{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.pyramid-header{text-align:center;padding:.5rem}.pyramid-header h3{margin:0 0 .3rem;font-size:1.1rem;font-weight:600;color:gold}.pyramid-header .subtitle{color:#888;font-size:.85rem}.pyramid-canvas-container{flex:1;display:flex;justify-content:center;align-items:center;background:#0a0a1e80;border-radius:12px;padding:1rem;min-height:350px}.pyramid-canvas-container canvas{max-width:100%;max-height:100%;border-radius:8px}.pyramid-controls{display:flex;justify-content:center;gap:.75rem;padding:.5rem;flex-wrap:wrap}.pyramid-controls .ctrl-btn{padding:.5rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ccc;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem}.pyramid-controls .ctrl-btn:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40}.pyramid-controls .ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.pyramid-controls .ctrl-btn.play{background:#00ff8826;border-color:#00ff884d;color:#0f8}.pyramid-controls .ctrl-btn.stop{background:#ff6b9d26;border-color:#ff6b9d4d;color:#ff6b9d}.level-selector{display:flex;align-items:center;gap:.5rem;padding:0 .75rem}.level-selector label{color:#888;font-size:.85rem}.level-selector input[type=range]{width:80px;accent-color:#ffd700}.level-selector .level-value{min-width:20px;color:gold;font-weight:700;font-size:.9rem}.energy-bar-container{padding:.5rem 1rem}.energy-bar{display:flex;height:28px;background:#0000004d;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.energy-segment{display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.5);cursor:pointer;transition:all .2s ease;min-width:0}.energy-segment:hover{filter:brightness(1.2)}.energy-segment.highlight{box-shadow:inset 0 0 0 2px #ffffff80}.energy-labels{display:flex;justify-content:space-between;padding:.3rem .5rem 0;font-size:.75rem;color:#888}.pyramid-sidebar{width:280px;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;overflow-y:auto}.pyramid-decomp-view.compact .pyramid-sidebar{width:240px}.pyramid-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.75rem}.pyramid-section h4{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:gold;display:flex;align-items:center;gap:.4rem}.pyramid-section p{margin:.3rem 0;font-size:.8rem;color:#aaa;line-height:1.4}.pyramid-section strong{color:#fff}.level-info{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem}.level-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#0003;border-radius:6px;font-size:.75rem}.level-row.active{background:#ffd70026;border:1px solid rgba(255,215,0,.3)}.level-row .level-num{font-weight:700;color:gold;min-width:50px}.level-row .level-size{color:#888}.level-row .level-bands{display:flex;gap:.25rem;margin-left:auto}.level-row .band-tag{padding:.1rem .3rem;border-radius:3px;font-size:.65rem;font-weight:600}.band-tag.ll{background:#00d4ff33;color:#00d4ff}.band-tag.lh{background:#ff9f4333;color:#ff9f43}.band-tag.hl{background:#c9b1ff33;color:#c9b1ff}.band-tag.hh{background:#ff6b9d33;color:#ff6b9d}.compression-note{background:#00ff8814;border:1px solid rgba(0,255,136,.2);border-radius:8px;padding:.6rem;margin-top:.5rem}.compression-note .formula{text-align:center;margin:.3rem 0}.compression-note .note-text{font-size:.75rem;color:#0f8}.color-ll{color:#00d4ff}.color-lh{color:#ff9f43}.color-hl{color:#c9b1ff}.color-hh{color:#ff6b9d}.anim-indicator{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#ffaa001a;border-radius:6px;margin-top:.5rem}.anim-indicator .pulse-dot{width:8px;height:8px;border-radius:50%;background:#fa0;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.anim-indicator .anim-text{font-size:.8rem;color:#fa0}.image-source-section select:hover{border-color:#ffffff40}@media (max-width: 1200px){.pyramid-sidebar{width:220px}}@media (max-width: 900px){.pyramid-decomp-view{flex-direction:column}.pyramid-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.pyramid-section{flex:1;min-width:200px}}.reconstruction-view{display:flex;gap:1.5rem;height:100%;padding:.5rem;background:var(--bg-dark, #0a0a1a)}.reconstruction-view.compact{padding:.25rem;gap:1rem}.reconstruction-main{flex:1;display:flex;flex-direction:column;gap:.75rem;min-width:0}.reconstruction-header{text-align:center;padding:.5rem}.reconstruction-header h3{margin:0 0 .3rem;font-size:1.1rem;font-weight:600;color:#0f8}.reconstruction-header .subtitle{color:#888;font-size:.85rem}.reconstruction-canvas-container{flex:1;display:flex;justify-content:center;align-items:center;background:#0a0a1e80;border-radius:12px;padding:1rem;min-height:300px}.reconstruction-canvas-container canvas{max-width:100%;max-height:100%;border-radius:8px}.mode-toggle{display:flex;justify-content:center;gap:.5rem;padding:.5rem}.mode-toggle button{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mode-toggle button:hover{background:#ffffff1a;color:#aaa}.mode-toggle button.active.lossless{background:linear-gradient(135deg,#00ff8826,#00c8641a);border-color:#0f86;color:#0f8}.mode-toggle button.active.lossy{background:linear-gradient(135deg,#ff6b9d26,#ff508c1a);border-color:#ff6b9d66;color:#ff6b9d}.reconstruction-controls{display:flex;justify-content:center;gap:.75rem;padding:.5rem;flex-wrap:wrap}.reconstruction-controls .ctrl-btn{padding:.5rem 1rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ccc;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem}.reconstruction-controls .ctrl-btn:hover:not(:disabled){background:#ffffff1f}.reconstruction-controls .ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.reconstruction-controls .ctrl-btn.play{background:#00ff8826;border-color:#00ff884d;color:#0f8}.reconstruction-controls .ctrl-btn.stop{background:#ff6b9d26;border-color:#ff6b9d4d;color:#ff6b9d}.lossy-controls{display:flex;justify-content:center;align-items:center;gap:1.5rem;padding:.5rem;background:#ff6b9d0d;border:1px solid rgba(255,107,157,.15);border-radius:8px;margin:0 1rem}.lossy-controls .quant-control{display:flex;align-items:center;gap:.5rem}.lossy-controls label{color:#ff6b9d;font-size:.85rem;font-weight:500}.lossy-controls input[type=range]{width:120px;accent-color:#ff6b9d}.lossy-controls .quant-value{min-width:30px;color:#ff6b9d;font-weight:700;font-size:.9rem}.metrics-display{display:flex;justify-content:center;gap:2rem;padding:.5rem}.metric{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;background:#0003;border-radius:8px}.metric .metric-label{font-size:.75rem;color:#888;margin-bottom:.2rem}.metric .metric-value{font-size:1.2rem;font-weight:700}.metric .metric-value.perfect{color:#0f8}.metric .metric-value.good{color:gold}.metric .metric-value.bad{color:#ff6b9d}.metric .metric-unit{font-size:.7rem;color:#666}.reconstruction-sidebar{width:280px;display:flex;flex-direction:column;gap:.75rem;padding:.5rem;overflow-y:auto}.reconstruction-view.compact .reconstruction-sidebar{width:240px}.recon-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.75rem}.recon-section h4{margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:#0f8;display:flex;align-items:center;gap:.4rem}.recon-section.lossy h4{color:#ff6b9d}.recon-section p{margin:.3rem 0;font-size:.8rem;color:#aaa;line-height:1.4}.recon-section strong{color:#fff}.formula-box{background:#0003;border-radius:8px;padding:.6rem;margin:.5rem 0;text-align:center}.formula-box .katex{font-size:.85rem}.formula-box.highlight{background:#00ff8814;border:1px solid rgba(0,255,136,.2)}.step-visual{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem;margin:.5rem 0}.step-box{padding:.4rem .6rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:.75rem;color:#888}.step-box.active{background:#ffd70026;border-color:#ffd7004d;color:gold}.step-arrow{color:#555;font-size:1rem}.comparison-box{display:flex;gap:.5rem;margin-top:.5rem}.comparison-item{flex:1;padding:.5rem;border-radius:6px;text-align:center}.comparison-item.original{background:#00d4ff1a;border:1px solid rgba(0,212,255,.2)}.comparison-item.reconstructed{background:#00ff881a;border:1px solid rgba(0,255,136,.2)}.comparison-item.error{background:#ff6b9d1a;border:1px solid rgba(255,107,157,.2)}.comparison-item .item-label{font-size:.7rem;color:#888;margin-bottom:.2rem}.comparison-item .item-icon{font-size:1.2rem}.image-source-section select{width:100%;padding:.4rem .6rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ddd;font-size:.8rem;cursor:pointer;margin-top:.3rem}.insight-box{background:#ffd70014;border:1px solid rgba(255,215,0,.2);border-radius:8px;padding:.6rem;margin-top:.5rem}.insight-box .insight-title{font-weight:700;color:gold;font-size:.85rem;margin-bottom:.3rem}.insight-box .insight-text{font-size:.75rem;color:#ccc}.color-lossless{color:#0f8}.color-lossy{color:#ff6b9d}.color-original{color:#00d4ff}.color-coef{color:gold}@media (max-width: 1200px){.reconstruction-sidebar{width:220px}}@media (max-width: 900px){.reconstruction-view{flex-direction:column}.reconstruction-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.recon-section{flex:1;min-width:200px}}.jpeg-pipeline-view{display:flex;flex-direction:column;height:100%;width:100%;padding:1rem}.jpeg-pipeline-view .panel{margin-bottom:1rem}.jpeg-pipeline-view .panel h2{color:gold;margin-bottom:.5rem}.jpeg-pipeline-view .description{color:#ffffffb3;font-size:.9rem}.stage-selector{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.stage-btn{display:flex;flex-direction:column;align-items:center;padding:.6rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffb3;cursor:pointer;transition:all .2s;min-width:90px}.stage-btn:hover{background:#ffffff1a;border-color:#fff3}.stage-btn.active{background:#ffd70026;border-color:#ffd70066;color:gold}.stage-btn .stage-icon{font-size:1.2rem;margin-bottom:.25rem}.stage-btn .stage-name{font-size:.75rem;font-weight:500}.stage-btn .stage-num{font-size:.65rem;opacity:.5;margin-top:.2rem}.jpeg-pipeline-view.compact-mode{padding:.5rem;height:100%;width:100%;display:flex;flex-direction:row;gap:.75rem}.stage-tabs{display:flex;flex-direction:column;gap:.4rem;order:2;flex-shrink:0;padding:.5rem;background:#0003;border-radius:8px;border:1px solid rgba(255,255,255,.08)}.stage-tab{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff9;cursor:pointer;transition:all .15s;font-size:.85rem}.stage-tab:hover{background:#ffffff14}.stage-tab.active{background:#ffd70026;border-color:#ffd70066;color:gold}.stage-tab .tab-icon{font-size:1rem}.stage-tab .tab-name{font-weight:500}.stage-content{flex:1;display:flex;flex-direction:column;background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:1rem;overflow:auto;min-height:0;order:1}.stage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.stage-header h4{margin:0;font-size:1.2rem;color:gold}.view-toggle{display:flex;gap:.4rem}.view-toggle button{padding:.4rem .8rem;font-size:.85rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#ffffffb3;cursor:pointer;transition:all .15s}.view-toggle button:hover{background:#ffffff1a}.view-toggle button.active{background:#00d4ff33;border-color:#00d4ff80;color:#00d4ff}.quality-slider{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#ffffffb3}.quality-slider input[type=range]{width:120px;accent-color:#ffd700}.anim-controls{display:flex;gap:.4rem}.anim-controls button{width:36px;height:32px;padding:0;font-size:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;cursor:pointer;transition:all .15s}.anim-controls button:hover{background:#ffffff1a}.formula-box{margin-top:1rem;padding:.75rem 1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;text-align:center;font-size:1.1rem}.formula-box.compact{font-size:1rem}.formula-box .note{margin-top:.5rem;font-size:.85rem;color:#ffffff80}.info-row{margin-top:1rem;padding:.6rem 1rem;background:#ffd7000d;border:1px solid rgba(255,215,0,.15);border-radius:6px;font-size:.9rem;color:#fffc;text-align:center}.info-row .highlight{color:gold;font-weight:600}.stage-content canvas{display:block;margin:0 auto;border-radius:8px;max-width:100%}.color-space-view,.chroma-subsampling-view,.dct-basis-view,.block-dct-view,.quantization-view,.zigzag-view{display:flex;flex-direction:column;align-items:center;width:100%;height:100%;flex:1}.image-selector{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#ffffffb3}.image-selector label{font-weight:500}.image-selector select{padding:.35rem .6rem;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.85rem;cursor:pointer;min-width:180px}.image-selector select:hover{background:#ffffff1f;border-color:#ffd70066}.image-selector select:focus{outline:none;border-color:#ffd70099}.image-selector select option{background:#1a1a2e;color:#fff}@media (max-width: 800px){.stage-tabs{justify-content:center}.stage-tab .tab-name{display:none}.summary-box{flex-direction:column}.controls-row{justify-content:center}}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;--font-mono: "Fira Code", "JetBrains Mono", Consolas, monospace;line-height:1.6;font-weight:400;color-scheme:dark;color:#ffffffe6;background-color:#0a0a1a;--primary: #00d9ff;--primary-dark: #0099cc;--primary-light: #66e5ff;--primary-alpha: rgba(0, 217, 255, .1);--secondary: #ff6b9d;--success: #00ff88;--warning: #ffaa00;--error: #ff4d6d;--purple: #c9b1ff;--bg-darker: #050510;--bg-dark: #0a0a1a;--bg-card: #12122a;--bg-elevated: #1a1a3a;--border: #2a2a4a;--border-light: #3a3a5a;--text-muted: #8888aa;--text-light: rgba(255, 255, 255, .85);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 8px 25px rgba(0, 0, 0, .3);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .5);--shadow-glow: 0 4px 15px rgba(0, 217, 255, .3);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-xxl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 50%;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 500;--z-modal: 1000;--z-tooltip: 1500;--view-width-sm: 800px;--view-width-md: 1000px;--view-width-lg: 1200px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;background-color:var(--bg-dark);color:#ffffffe6;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}::selection{background:var(--primary-alpha);color:var(--primary)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.app{display:flex;height:100vh;overflow:hidden;background:var(--bg-dark)}.app.sidebar-collapsed .sidebar{width:0;padding:0;overflow:hidden;border-right:none}.app.sidebar-collapsed .sidebar>*{opacity:0;visibility:hidden}.app.sidebar-collapsed .main-content{max-width:100%}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.nav-arrows{display:flex;align-items:center;justify-content:center;gap:var(--space-xl);padding:.6rem var(--space-lg);background:var(--bg-card);border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-toggle{position:absolute;left:var(--space-md);width:36px;height:36px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);font-size:1rem;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;padding:0}.sidebar-toggle:hover{background:var(--primary);color:var(--bg-dark);border-color:var(--primary)}.nav-arrows-center{display:flex;align-items:center;justify-content:center;gap:var(--space-lg)}.nav-arrow{width:44px;height:44px;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--primary);font-size:1.3rem;cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center;padding:0}.nav-arrow:hover:not(:disabled){background:var(--primary);color:var(--bg-dark);transform:scale(1.05)}.nav-arrow:disabled{opacity:.3;cursor:not-allowed}.section-indicator{font-size:.95rem;color:var(--text-muted);min-width:60px;text-align:center;font-weight:500}.content-area{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;min-height:0}.content-area>div{flex:1 0 auto;min-height:fit-content}.wavelet-playground,.wavelet-playground-v2,.fourier-view,.convolution-view,.filters-view,.decompose-view,.denoise-view,.compare-view,.wavelet-basis-view,.wavelet-education-view{padding-bottom:var(--space-lg)}.content-area .wavelet-playground-v2{min-height:600px;height:calc(100vh - 160px)}@media (max-width: 768px){.app{flex-direction:column}.content-area{padding:var(--space-md)}.sidebar-toggle{display:none}.nav-arrows{position:relative}}.sidebar{width:240px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease,padding .3s ease,opacity .3s ease;overflow:hidden}.sidebar>*{transition:opacity .2s ease,visibility .2s ease}.sidebar-header{padding:var(--space-lg);text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-card) 100%)}.sidebar-header h1{font-size:1.8rem;color:var(--primary);margin-bottom:.2rem}.sidebar-header p{font-size:.9rem;color:var(--text-muted)}.nav-sections{flex:1;padding:var(--space-md) var(--space-sm);overflow-y:auto}.nav-item{display:flex;align-items:center;width:100%;padding:.8rem var(--space-md);margin-bottom:.3rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-normal);text-align:left;font-size:.95rem}.nav-item:hover{background:var(--bg-elevated);color:#fff}.nav-item.active{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);color:var(--bg-dark);font-weight:600}.nav-icon{font-size:1.2rem;margin-right:.8rem;width:24px;text-align:center}.nav-label{flex:1}.nav-number{font-size:.75rem;opacity:.5;background:var(--bg-darker);padding:.2rem var(--space-sm);border-radius:var(--radius-sm)}.nav-item.active .nav-number{background:#0003;opacity:1}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border)}.image-selector{margin-bottom:var(--space-md)}.image-selector label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.4rem}.image-selector select{width:100%;padding:var(--space-sm);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:#fff;font-size:.9rem}.guided-toggle{width:100%;padding:.7rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--primary);cursor:pointer;transition:all var(--transition-normal);font-size:.9rem}.guided-toggle:hover{background:var(--primary);color:var(--bg-dark)}.guided-toggle.active{background:var(--secondary);color:#fff;border-color:var(--secondary)}@media (max-width: 768px){.sidebar{width:100%;height:auto;border-right:none;border-bottom:1px solid var(--border)}.nav-sections{display:flex;overflow-x:auto;padding:var(--space-sm)}.nav-item{flex-direction:column;padding:var(--space-sm);min-width:80px;text-align:center}.nav-icon{margin-right:0;margin-bottom:.3rem}.nav-label{font-size:.75rem}.nav-number,.sidebar-footer{display:none}}.slide-section-header{text-align:center;margin-bottom:var(--space-sm);padding:var(--space-xs) var(--space-md)}.slide-section-header h2{font-size:1.1rem;color:var(--primary);margin:0 0 .25rem;font-weight:600}.slide-section-header p{font-size:.85rem;color:var(--text-muted);margin:0}.view-container{max-width:var(--view-width-md);margin:0 auto}.view-container--sm{max-width:var(--view-width-sm);margin:0 auto}.view-container--lg{max-width:var(--view-width-lg);margin:0 auto}.toggle-btn-group{display:flex;gap:var(--space-xs);flex-wrap:wrap}.toggle-btn-group--bg{background:var(--bg-darker);padding:var(--space-xs);border-radius:var(--radius-md);width:fit-content}.toggle-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;min-width:60px}.toggle-btn:hover:not(.active):not(:disabled){border-color:var(--primary);color:var(--text-light);background:var(--bg-card)}.toggle-btn.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-color:var(--primary);color:var(--bg-dark);font-weight:500}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.panel h2{color:var(--primary);margin-bottom:var(--space-md);font-size:1.5rem}.panel h3{color:#a0e7ff;margin-bottom:.8rem;font-size:1.2rem}.info-box{background:var(--bg-elevated);border-left:4px solid var(--primary);padding:var(--space-md) 1.2rem;margin:var(--space-md) 0;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:.95rem}.info-box.warning{border-left-color:var(--warning)}.info-box.success{border-left-color:var(--success)}.info-box.error{border-left-color:var(--error)}.insight-box{margin-top:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#ffaa001a,#ffaa000d);border-left:4px solid var(--warning);border-radius:var(--radius-md)}.insight-box strong{color:var(--warning)}.image-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.image-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);text-align:center}.image-card h4{color:var(--primary);margin-bottom:.8rem;font-size:1rem}.image-card img{max-width:100%;height:auto;border-radius:var(--radius-sm);image-rendering:pixelated}.metrics{display:flex;gap:.8rem;justify-content:center;margin-top:.8rem;flex-wrap:wrap}.metric{background:var(--bg-darker);padding:.3rem .7rem;border-radius:var(--radius-sm);font-size:.85rem}.metric span{color:var(--primary);font-weight:600}.plot-container{background:var(--bg-darker);border-radius:var(--radius-md);padding:var(--space-md);margin:var(--space-md) 0}canvas{display:block;max-width:100%;border-radius:var(--radius-sm)}.loading{display:flex;align-items:center;justify-content:center;gap:.8rem;padding:var(--space-xl);color:var(--text-muted)}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}.error{background:#ff6b9d1a;border:1px solid var(--secondary);color:var(--secondary);padding:var(--space-md);border-radius:var(--radius-md);margin:var(--space-md) 0}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);margin:var(--space-xl) 0}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;transition:transform var(--transition-normal),border-color var(--transition-normal)}.feature-card:hover{transform:translateY(-4px);border-color:var(--primary)}.feature-card .icon{font-size:2.5rem;margin-bottom:var(--space-md)}.feature-card h3{color:var(--primary);margin-bottom:var(--space-sm)}.feature-card p{color:var(--text-muted);font-size:.9rem}.animation-focus-layout{display:flex;flex-direction:column;height:100%;max-width:1200px;margin:0 auto}.animation-focus-layout .visualization-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:var(--space-md)}.animation-focus-layout .visualization-area canvas{max-width:100%;height:auto;border-radius:var(--radius-md)}.animation-focus-layout .controls-below{flex-shrink:0;padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-lg);margin-top:var(--space-md)}.panel-compact{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md)}.panel-compact h2{color:var(--primary);margin-bottom:var(--space-sm);font-size:1.3rem}.panel-compact h3{color:#a0e7ff;margin-bottom:.5rem;font-size:1.1rem}.image-selector-inline{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border)}.image-selector-inline label{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.image-selector-inline select{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-light);font-size:.9rem;cursor:pointer;transition:border-color var(--transition-fast)}.image-selector-inline select:hover{border-color:var(--primary)}.image-selector-inline select:focus{outline:none;border-color:var(--primary)}.plot-with-labels{position:relative}.plot-label{position:absolute;pointer-events:none;z-index:10}.plot-label--title{top:4px;left:50px;font-size:1rem;font-weight:700}.plot-label--title-cyan{color:var(--primary)}.plot-label--title-pink{color:var(--secondary)}.plot-label--title-green{color:var(--success)}.plot-label--ylabel{left:4px;top:50%;transform:translateY(-50%) rotate(-90deg);font-size:.9rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.plot-label--xlabel{right:10px;bottom:8px;font-size:.75rem;font-weight:600;color:var(--text-muted)}.plot-legend{position:absolute;top:8px;right:12px;background:#050510d9;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:6px 10px;display:flex;flex-direction:column;gap:4px;pointer-events:none}.plot-legend__entry{display:flex;align-items:center;gap:8px;font-size:.7rem;color:#fffc}.plot-legend__line{width:20px;height:3px;border-radius:1px}.plot-legend__line--gray{background:#88a9}.plot-legend__line--cyan{background:#00d9ff66}.plot-legend__line--green{background:var(--success)}.plot-legend__line--pink{background:var(--secondary)}.control-section{background:var(--bg-elevated);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border)}.control-section h4{margin-bottom:.75rem;color:var(--primary);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.control-section.full-width{grid-column:1 / -1}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-lg)}.explanation-card{background:var(--bg-darker);padding:var(--space-md);border-radius:var(--radius-md);border-left:4px solid var(--border)}.explanation-card h4{color:var(--text-light);margin-bottom:var(--space-sm)}.explanation-card p{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin-bottom:var(--space-sm)}.explanation-card--primary{border-left-color:var(--primary)}.explanation-card--secondary{border-left-color:var(--secondary)}.explanation-card--success{border-left-color:var(--success)}.explanation-card--warning{border-left-color:var(--warning)}.explanation-card--purple{border-left-color:var(--purple)}.image-comparison-grid{display:grid;gap:var(--space-lg)}.image-comparison-grid--2col{grid-template-columns:repeat(2,1fr)}.image-comparison-grid--single{grid-template-columns:1fr;max-width:600px;margin:0 auto}@media (max-width: 768px){.image-comparison-grid--2col,.explanation-cards{grid-template-columns:1fr}}.controls{display:flex;gap:var(--space-md);align-items:flex-end;flex-wrap:wrap;margin-bottom:var(--space-md)}.control-group{display:flex;flex-direction:column;gap:.3rem}.control-group label{font-size:.85rem;color:var(--text-muted)}.control-group.inline{display:flex;flex-direction:row;align-items:center;gap:var(--space-md);margin-top:var(--space-md)}.controls-row{display:flex;align-items:flex-end;gap:var(--space-xl);margin-bottom:var(--space-lg);flex-wrap:wrap}.control-group input[type=range]{width:150px;accent-color:var(--primary)}.control-group select{padding:var(--space-sm);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:#fff;min-width:150px}.control-group input[type=text]{padding:var(--space-sm) .8rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:#fff;font-family:Fira Code,monospace;min-width:300px}.control-group input[type=text]:focus{outline:none;border-color:var(--primary)}.range-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-top:.3rem}button{padding:.6rem 1.2rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--primary);cursor:pointer;transition:all var(--transition-normal);font-size:.95rem;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1.2}button:hover:not(:disabled){background:var(--primary);color:var(--bg-dark)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--primary);color:var(--bg-dark);border-color:var(--primary)}button.primary:hover{background:var(--primary-dark)}button.active{background:var(--primary);color:var(--bg-dark)}.animate-btn{padding:.8rem var(--space-lg);border-radius:var(--radius-md);border:none;background:var(--bg-elevated);color:#fff;cursor:pointer;transition:all var(--transition-normal);font-size:.95rem}.animate-btn:hover{background:var(--primary-dark)}.animate-btn.active{background:var(--secondary);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.button-group{display:flex;gap:var(--space-sm);flex-wrap:wrap}.button-group button{flex:1;min-width:80px;padding:.6rem var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all var(--transition-normal);font-size:.85rem}.button-group button:hover{background:var(--bg-elevated);color:#fff;border-color:var(--primary)}.button-group button.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--bg-dark);border-color:var(--primary);font-weight:600}.slider-wide{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-card);border-radius:var(--radius-sm);outline:none;margin:var(--space-sm) 0}.slider-wide::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-full);cursor:pointer;box-shadow:var(--shadow-glow);transition:transform var(--transition-normal)}.slider-wide::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider-wide::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-full);cursor:pointer;border:none;box-shadow:var(--shadow-glow)}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-top:var(--space-xs)}@media (max-width: 900px){.controls-row{flex-direction:column;align-items:stretch}}.math-block{background:var(--bg-darker);padding:var(--space-lg);margin:var(--space-md) 0;border-radius:var(--radius-md);text-align:center;font-family:KaTeX_Main,serif;font-size:1.2rem;overflow-x:auto}.math-block.primary{border-left:4px solid var(--primary)}.math-block.secondary{border-left:4px solid var(--success)}.math-block.tertiary{border-left:4px solid var(--purple)}.math-block.highlight{border-left:4px solid var(--warning);font-size:1.2rem;text-align:center;font-family:Courier New,monospace;color:var(--warning)}.math-block code{font-family:Courier New,monospace;font-size:1.05rem;color:var(--primary);background:none;padding:0}.math-inline{font-family:KaTeX_Main,serif;color:var(--primary)}.math-label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:var(--space-sm)}.math-note{color:var(--text-muted);font-style:italic;margin-top:var(--space-sm)}.latex-block{display:block;margin:var(--space-sm) 0}.latex-inline{display:inline}.katex{font-size:1.1em}.katex-display{margin:var(--space-sm) 0}.math-panel{background:linear-gradient(135deg,var(--bg-card),var(--bg-elevated))}.math-definitions{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.transform-formula{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border)}.transform-formula h4{margin-bottom:var(--space-md);color:var(--text-muted)}.formula-explanation{margin-top:var(--space-md);color:var(--text-muted);font-size:.95rem}.filter-equation-display{background:var(--bg-card);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border);margin:var(--space-md) 0;text-align:center}.filter-equation-display h4{color:var(--text-muted);font-size:.8rem;margin-bottom:var(--space-sm);text-transform:uppercase}.tour-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:linear-gradient(135deg,#0f1117,#1a1d24);z-index:9999;display:flex;flex-direction:row;overflow:hidden!important;box-sizing:border-box;margin:0;padding:0}.tour-fullscreen.no-scroll{overflow:hidden!important}.tour-fullscreen:focus{outline:none}.tour-close-btn{position:absolute;top:.5rem;right:.5rem;width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:#0006;color:#fff;font-size:1.2rem;cursor:pointer;transition:all .2s;z-index:100;display:flex;align-items:center;justify-content:center}.tour-close-btn:hover{background:#ff4757;border-color:#ff4757;transform:scale(1.1)}.tour-progress{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:3.5rem .5rem .5rem;background:#00000080;border-right:1px solid rgba(255,255,255,.1);flex-shrink:0;width:56px;height:100vh;overflow-y:auto}.tour-section-btn{position:relative;width:40px;height:40px;border-radius:8px;border:2px solid rgba(255,255,255,.15);background:#ffffff0d;flex-shrink:0;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.tour-section-btn .sec-icon{font-size:1.2rem;opacity:.5;transition:opacity .2s}.tour-section-btn:hover{border-color:var(--sec-color, #00d4ff);transform:translateY(-2px)}.tour-section-btn:hover .sec-icon{opacity:1}.tour-section-btn.active{border-color:var(--sec-color, #00d4ff);background:linear-gradient(135deg,#00d4ff33,#00d4ff1a);box-shadow:0 0 20px #00d4ff4d}.tour-section-btn.active .sec-icon{opacity:1}.tour-section-btn.completed{border-color:#2ecc71;background:#2ed57326}.tour-section-btn.completed .sec-icon{opacity:.8}.sec-dots{position:absolute;right:-8px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:2px}.sec-dot{width:4px;height:4px;border-radius:50%;background:#ffffff4d;transition:all .2s}.sec-dot.active{background:var(--sec-color, #00d4ff);box-shadow:0 0 4px var(--sec-color, #00d4ff)}.tour-main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;overflow:hidden;position:relative}.tour-slide{flex:1;display:flex;align-items:center;justify-content:center;padding:.75rem;overflow:hidden!important;min-height:0;box-sizing:border-box}.slide-title{text-align:center;animation:fadeIn .5s ease}.slide-title .slide-icon{font-size:5rem;margin-bottom:1rem;filter:drop-shadow(0 4px 20px rgba(0,212,255,.4))}.slide-title h1{font-size:clamp(2.5rem,5vw,4rem);font-weight:700;color:var(--slide-color, #00d4ff);margin-bottom:.5rem;text-shadow:0 2px 30px rgba(0,212,255,.4)}.slide-title h2{font-size:clamp(1rem,2vw,1.5rem);color:#fff9;font-weight:400}.slide-toc{max-width:1000px;width:100%;animation:fadeIn .5s ease;display:flex;flex-direction:column;align-items:center}.toc-header{text-align:center;margin-bottom:1.5rem}.toc-header .toc-icon{font-size:3rem;display:block;margin-bottom:.5rem}.toc-header h1{font-size:clamp(1.8rem,4vw,2.5rem);color:var(--slide-color, #00d4ff);margin:0 0 .25rem}.toc-header h2{font-size:clamp(.9rem,1.5vw,1.1rem);color:#ffffff80;font-weight:400;margin:0}.toc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;width:100%}.toc-item{display:flex;align-items:center;gap:.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.75rem 1rem;transition:all .2s}.toc-item.clickable{cursor:pointer}.toc-item:hover{background:#ffffff14;border-color:var(--slide-color, #00d4ff);transform:translateY(-2px)}.toc-item.clickable:active{transform:translateY(0)}.toc-item-icon{font-size:1.5rem;flex-shrink:0}.toc-item-text{display:flex;flex-direction:column;gap:.1rem}.toc-item-title{font-size:.95rem;font-weight:600;color:#fff}.toc-item-desc{font-size:.75rem;color:#ffffff80}@media (max-width: 900px){.toc-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.toc-grid{grid-template-columns:1fr}}.slide-theory{max-width:900px;width:100%;animation:fadeIn .5s ease}.slide-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.slide-icon-sm{font-size:2.5rem}.slide-header h1{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--slide-color, #00d4ff);margin:0}.slide-content{font-size:1.2rem;color:#ffffffd9;line-height:1.6;margin-bottom:1.5rem;text-align:center}.slide-math{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;text-align:center}.slide-math .math-formula{font-size:1.3rem;color:var(--slide-color, #00d4ff);margin-bottom:.5rem}.slide-math .math-label{font-size:.85rem;color:#ffffff80;text-transform:uppercase;letter-spacing:1px}.slide-points{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}.slide-points li{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#ffffff0d;border-radius:8px;font-size:1.1rem;color:#ffffffe6}.slide-points li:before{content:"▸";color:var(--slide-color, #00d4ff);font-weight:700}.slide-theory-visual{max-width:1200px;width:100%;height:calc(100% - 60px);display:flex;flex-direction:column;animation:fadeIn .5s ease;overflow:visible;min-height:0;transform-origin:top center;padding:0 1rem}.slide-theory-visual .slide-header.compact{margin-bottom:.5rem;flex-shrink:0}.slide-theory-visual .slide-header.compact h1{font-size:1.8rem}.slide-theory-visual .slide-content.compact{font-size:1.05rem;margin-bottom:.75rem;flex-shrink:0;line-height:1.5}.slide-theory-visual .slide-math.compact{padding:.6rem 1rem;margin-bottom:.75rem;flex-shrink:0}.slide-theory-visual .slide-math.compact .math-formula{font-size:1.2rem}.kernel-matrix-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:.5rem}.kernel-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.4rem .5rem;text-align:center}.kernel-card h4{color:var(--slide-color, #c9b1ff);margin:0 0 .25rem;font-size:.85rem}.kernel-matrix{background:#0000004d;border-radius:4px;padding:.25rem;margin-bottom:.25rem;font-size:.75rem}.kernel-matrix .katex{font-size:.7rem}.kernel-card p{margin:0;font-size:.7rem;color:#fff9}.wavelet-connection-box{background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:10px;padding:.75rem 1rem}.wavelet-connection-box h4{margin:0 0 .4rem;color:#00d4ff;font-size:.95rem}.wavelet-connection-box p{margin:0 0 .5rem;font-size:.9rem;color:#fffc}.wavelet-connection-box .math-formula.small{font-size:.85rem;background:#0003;border-radius:6px;padding:.4rem}.dwt2d-section{background:#c9b1ff1a;border:1px solid rgba(201,177,255,.3);border-radius:12px;padding:1rem 1.5rem;margin-top:.75rem;flex:1;display:flex;flex-direction:column;min-height:0}.dwt2d-section h3{margin:0 0 .5rem;color:#c9b1ff;font-size:1.3rem;flex-shrink:0}.dwt2d-section .dwt2d-desc{margin:0 0 .75rem;font-size:1.05rem;color:#ffffffe6;flex-shrink:0}.dwt2d-coefficients{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,auto);gap:1rem;flex:0 0 auto}.dwt2d-coeff{background:#0000004d;border-radius:10px;padding:1rem 1.25rem;text-align:center;display:flex;flex-direction:column;justify-content:center;gap:.4rem}.dwt2d-coeff .coeff-name{font-weight:700;font-size:1.6rem;color:#c9b1ff}.dwt2d-coeff .coeff-formula{font-size:1rem;color:#fffffff2}.dwt2d-coeff .coeff-formula .katex{font-size:1rem}.dwt2d-coeff .coeff-desc{font-size:.9rem;color:#ffffffbf}.dwt2d-subsampling{background:#0003;border-radius:8px;padding:.75rem;text-align:center;font-size:1rem;margin-top:.75rem;flex-shrink:0}.dwt2d-subsampling .katex{font-size:1rem}.slide-comparison{max-width:1000px;width:100%;animation:fadeIn .5s ease}.comparison-grid{display:flex;align-items:stretch;gap:2rem;margin-top:1.5rem}.comp-col{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.comp-col h3{text-align:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1);font-size:1.3rem}.comp-col.dct h3{color:#f39c12}.comp-col.wavelet h3{color:#00d4ff}.comp-col ul{list-style:none;padding:0;margin:0}.comp-col li{padding:.5rem 0;color:#fffc;text-align:center}.comp-vs{display:flex;align-items:center;font-size:2rem;font-weight:700;color:#ffffff4d}.slide-demo{width:100%;max-width:1100px;height:100%;max-height:100%;display:flex;flex-direction:column;animation:fadeIn .5s ease;box-sizing:border-box;overflow:hidden}.slide-demo .slide-header{margin-bottom:.75rem;flex-shrink:0}.demo-container{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.slide-embed{width:100%;height:100%;display:flex;flex-direction:column;animation:fadeIn .4s ease;overflow:hidden}.embed-wrapper{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;background:#0003;border-radius:12px;padding:1rem}.embed-wrapper::-webkit-scrollbar{width:8px}.embed-wrapper::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.embed-wrapper::-webkit-scrollbar-thumb{background:#00d4ff4d;border-radius:4px}.embed-wrapper::-webkit-scrollbar-thumb:hover{background:#00d4ff80}.embed-wrapper .view-container,.embed-wrapper .view-section,.embed-wrapper .playground-container{background:transparent!important;max-width:100%!important;margin:0!important;padding:0!important}.embed-wrapper .card,.embed-wrapper .section-card{margin-bottom:.75rem}.embed-wrapper img,.embed-wrapper canvas{max-width:100%;height:auto}.compact-demo{width:100%;max-width:800px;display:flex;flex-direction:column;gap:1rem}.compact-controls{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#0000004d;border-radius:10px}.compact-controls.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.compact-controls label{color:#ffffffb3;font-size:.9rem}.compact-controls select{padding:.5rem 1rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:.95rem;cursor:pointer}.compact-controls select:focus{outline:none;border-color:var(--slide-color, #00d4ff)}.slider-row{display:flex;align-items:center;gap:.75rem;flex:1}.slider-row span{color:#fffc;font-size:.9rem;min-width:100px}.slider-row input[type=range]{flex:1;height:6px;border-radius:3px;background:#fff3;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.slider-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--slide-color, #00d4ff);cursor:pointer}.compact-visual{display:flex;justify-content:center;align-items:center;background:#0000004d;border-radius:10px;padding:1rem;min-height:200px;max-height:300px}.compact-visual img{max-width:100%;max-height:280px;object-fit:contain;border-radius:6px}.compact-compare{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.compact-compare.three-col{grid-template-columns:1fr 1fr 1fr}.compare-img{display:flex;flex-direction:column;align-items:center;gap:.5rem}.compare-img span{font-size:.85rem;color:#ffffffb3;font-weight:500}.compare-img img{width:100%;max-height:180px;object-fit:contain;border-radius:8px;background:#0000004d}.demo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:150px;background:#ffffff0d;border:2px dashed rgba(255,255,255,.2);border-radius:8px;color:#ffffff80;font-size:1.2rem}.conv-animation{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.conv-signal{display:flex;gap:4px}.conv-cell{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#00d4ff33;border:2px solid rgba(0,212,255,.4);border-radius:8px;color:#fff;font-weight:600;transition:all .3s}.conv-cell.highlight{background:#00d4ff80;border-color:#00d4ff;transform:scale(1.1)}.conv-cell.kernel{background:#ff9f434d;border-color:#ff9f43}.conv-kernel{display:flex;gap:4px;transition:transform .3s ease}.conv-label{color:#fff9;font-size:.9rem}.compact-playground canvas{width:100%;max-width:500px;height:200px;border-radius:10px;background:#1a1d24}.slide-final{text-align:center;animation:fadeIn .5s ease}.slide-final .slide-icon.large{font-size:6rem;margin-bottom:1rem}.slide-final h1{font-size:3.5rem;color:var(--slide-color, #2ecc71);margin-bottom:.5rem}.slide-final h2{font-size:1.3rem;color:#fff9;margin-bottom:1.5rem}.final-message{font-size:1.1rem;color:#fffc;margin-bottom:2rem;max-width:500px}.btn-explore{padding:1rem 2.5rem;border-radius:50px;border:none;background:linear-gradient(135deg,#00d4ff,#0097b2);color:#0f1117;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-explore:hover{transform:translateY(-3px);box-shadow:0 10px 30px #00d4ff66}.tour-nav{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1.5rem;background:#00000080;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0;height:44px}.nav-btn{padding:.4rem 1rem;border-radius:6px;border:2px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s;min-width:100px}.nav-btn:hover:not(:disabled){border-color:#00d4ff;background:#00d4ff26;color:#00d4ff}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-center{display:flex;flex-direction:column;align-items:center;gap:.25rem}.slide-counter{font-size:1rem;font-weight:600;color:#00d4ff;background:#00d4ff1a;padding:.25rem .75rem;border-radius:20px}.nav-hint{font-size:.75rem;color:#fff6}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-filters-theory{width:100%;max-width:1200px;animation:fadeIn .5s ease;display:flex;flex-direction:column;gap:1rem}.slide-filters-theory .slide-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.slide-filters-theory .slide-header h1{font-size:2rem;color:#ff6b6b;margin:0}.slide-filters-theory .slide-content{color:#fffc;font-size:1.1rem;line-height:1.6;text-align:center;margin-bottom:1rem}.filters-formulas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.formula-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.formula-card h3{color:#ffd93d;font-size:1.1rem;margin:0;text-align:center}.formula-card .math-formula{background:#0000004d;padding:1rem;border-radius:8px;text-align:center;font-size:.95rem}.formula-card .formula-desc{color:#ffffffb3;font-size:.9rem;line-height:1.5;margin:0;text-align:center}.slide-fourier-interactive{width:100%;height:100%;display:flex;flex-direction:column;animation:fadeIn .4s ease;overflow:hidden}.slide-fourier-interactive .slide-header.compact{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;flex-shrink:0}.slide-fourier-interactive .slide-header.compact h1{font-size:1.1rem;color:#ffd93d;margin:0}.fourier-demo-wrapper{flex:1;min-height:0;overflow:hidden;background:#0003;border-radius:8px;padding:.5rem;display:flex;flex-direction:column}.fourier-demo-wrapper .fourier-view.fourier-compact{height:100%}.fourier-demo-wrapper .fourier-compact-layout{flex:1;min-height:0}.fourier-demo-wrapper .fourier-view.fourier-compact .fourier-plots{gap:.6rem}.fourier-demo-wrapper .fourier-view.fourier-compact .plot-container-with-overlay canvas{min-height:100px}.slide-filters-interactive{width:100%;height:100%;display:flex;flex-direction:column;animation:fadeIn .4s ease;overflow:hidden}.slide-filters-interactive .slide-header.compact{display:flex;align-items:center;gap:.5rem;padding:.15rem 0;flex-shrink:0}.slide-filters-interactive .slide-header.compact h1{font-size:1.1rem;color:#ff6b6b;margin:0}.filters-demo-wrapper{flex:1;min-height:0;overflow:hidden;background:#0003;border-radius:8px;padding:.25rem}.filters-demo-wrapper .filters-view.compact-mode{height:100%}.filters-view.compact-mode{display:flex;flex-direction:column;gap:.35rem;padding:.15rem;height:100%}.filters-view.compact-mode .plot-panel.compact{background:transparent;padding:0;margin:0;flex:1;display:flex;flex-direction:column}.filters-view.compact-mode .plot-container-with-overlay{flex:1;height:auto!important;min-height:120px}.sidebar-controls-panel{position:fixed;top:50%;right:20px;transform:translateY(-50%);width:230px;background:#141923f2;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:1rem;z-index:100;box-shadow:0 8px 30px #0006}.sidebar-controls-panel h4{margin:0 0 .75rem;color:#ff6b6b;font-size:.9rem;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-controls-panel .control-row{margin-bottom:.75rem}.sidebar-controls-panel .control-row:last-child{margin-bottom:0}.sidebar-controls-panel .control-row label{display:block;color:#ffffffd9;font-size:.8rem;margin-bottom:.4rem;font-weight:500}.sidebar-controls-panel .control-row label strong{color:#fa0}.sidebar-controls-panel .button-group.mini{display:flex;gap:.3rem}.sidebar-controls-panel .button-group.mini button{flex:1;padding:.4rem .5rem;font-size:.8rem;font-weight:500;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#ffffffb3;cursor:pointer;transition:all .2s}.sidebar-controls-panel .button-group.mini button:hover{background:#ffffff1a;border-color:#ffffff4d}.sidebar-controls-panel .button-group.mini button.active{border-color:var(--slide-color, #00d4ff);background:#00d4ff33;color:#fff}.sidebar-controls-panel .button-group.mini button.active.success{border-color:#0f8;background:#0f83}.sidebar-controls-panel .button-group.mini button.active.danger{border-color:#ff6b9d;background:#ff6b9d33}.sidebar-controls-panel input[type=range]{width:100%;margin-top:.3rem;height:6px;-webkit-appearance:none;background:#ffffff1a;border-radius:3px;outline:none}.sidebar-controls-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fa0;cursor:pointer;box-shadow:0 2px 6px #0000004d}.sidebar-controls-panel select{width:100%;padding:.5rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;font-size:.8rem;cursor:pointer}.sidebar-controls-panel select:hover{border-color:#ffffff4d}.sidebar-controls-panel select option{background:#1a1d24;color:#fff}.mobile-controls-btn{display:none;position:fixed;top:10px;right:60px;padding:.5rem 1rem;background:linear-gradient(135deg,#ff6b6b,#ff8e53);border:none;border-radius:20px;color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;z-index:1000;box-shadow:0 4px 20px #ff6b6b66;transition:all .2s}.mobile-controls-btn:hover{transform:scale(1.05);box-shadow:0 6px 25px #ff6b6b80}.mobile-controls-panel{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:300px;background:#141923fa;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:1rem;z-index:1001;box-shadow:0 10px 40px #00000080}.mobile-controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.mobile-controls-header h4{margin:0;color:#ff6b6b;font-size:1rem}.mobile-controls-panel .close-btn{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:transparent;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.mobile-controls-panel .close-btn:hover{background:#ff4757;border-color:#ff4757}.mobile-controls-panel .control-row{margin-bottom:.75rem}.mobile-controls-panel .control-row label{display:block;color:#ffffffd9;font-size:.85rem;margin-bottom:.4rem}.mobile-controls-panel .control-row label strong{color:#fa0}.mobile-controls-panel .button-group.mini{display:flex;gap:.3rem}.mobile-controls-panel .button-group.mini button{flex:1;padding:.5rem;font-size:.8rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#ffffffb3;cursor:pointer;transition:all .2s}.mobile-controls-panel .button-group.mini button.active{color:#fff}.mobile-controls-panel .button-group.mini button.active.success{border-color:#0f8;background:#0f83}.mobile-controls-panel .button-group.mini button.active.danger{border-color:#ff6b9d;background:#ff6b9d33}.mobile-controls-panel input[type=range]{width:100%;margin-top:.3rem}.mobile-controls-panel select{width:100%;padding:.5rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#fff;font-size:.85rem}.mobile-controls-panel select option{background:#1a1d24;color:#fff}@media (max-width: 900px){.sidebar-controls-panel{display:none!important}.mobile-controls-btn,.mobile-controls-panel{display:block!important}}.slide-theory.wavelet-connection{max-width:1000px}.slide-theory.wavelet-connection .slide-points li{margin-bottom:.75rem}.slide-theory.wavelet-connection .slide-points li strong{color:#ff6b6b}.slide-math.small .math-formula{font-size:.9rem;padding:.75rem;background:#0003;border-radius:8px;margin-top:1rem}@media (max-width: 768px){.tour-progress{padding:.5rem;gap:.25rem;height:auto;flex-wrap:wrap}.tour-section-btn{width:36px;height:36px}.sec-icon{font-size:1rem}.tour-slide{padding:1rem}.slide-title .slide-icon{font-size:3rem}.slide-title h1{font-size:2rem}.comparison-grid{flex-direction:column}.comp-vs{justify-content:center;font-size:1.5rem}.compact-compare,.compact-compare.three-col{grid-template-columns:1fr}.filters-formulas-grid{grid-template-columns:1fr;gap:1rem}.sidebar-controls-panel{width:120px;right:10px;padding:.5rem}.tour-nav{padding:.5rem 1rem;height:auto}.nav-btn{padding:.5rem 1rem;min-width:90px;font-size:.85rem}}.wavelet-education-view{max-width:1000px;margin:0 auto}.wavelet-education-view .subtitle{color:var(--text-muted);margin-top:var(--space-sm)}.wavelet-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md);margin-top:var(--space-lg)}.wavelet-card{display:flex;flex-direction:column;align-items:center;padding:1.2rem var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--border);background:var(--bg-elevated);cursor:pointer;transition:all var(--transition-slow)}.wavelet-card:hover{border-color:var(--card-color, var(--primary));transform:translateY(-3px);box-shadow:var(--shadow-md)}.wavelet-card.active{border-color:var(--card-color, var(--primary));background:linear-gradient(135deg,var(--bg-elevated),rgba(var(--card-color),.1));box-shadow:0 0 20px color-mix(in srgb,var(--card-color, var(--primary)) 30%,transparent)}.wavelet-icon{font-size:2rem;margin-bottom:var(--space-sm)}.wavelet-icon-large{font-size:3rem;margin-right:var(--space-md)}.wavelet-name{font-weight:600;font-size:1rem;color:#fff}.wavelet-category{font-size:.75rem;color:var(--text-muted);margin-top:.3rem}.wavelet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.wavelet-title{display:flex;align-items:center}.wavelet-title h2{margin-bottom:.2rem}.wavelet-origin{color:var(--text-muted);font-size:.9rem}.wavelet-badge{padding:.4rem var(--space-md);border-radius:20px;font-size:.8rem;font-weight:600;color:var(--bg-dark)}.wavelet-description{font-size:1.1rem;line-height:1.7;color:var(--text-light);margin-bottom:var(--space-lg)}.properties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.property-list{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:var(--space-lg)}.property-list h4{margin-bottom:var(--space-md);color:var(--primary)}.property-list.advantages h4{color:var(--success)}.property-list.disadvantages h4{color:var(--secondary)}.property-list ul{list-style:none}.property-list li{padding:.4rem 0 .4rem 1.2rem;position:relative;color:var(--text-light);font-size:.95rem}.property-list li:before{content:"•";position:absolute;left:0;color:var(--text-muted)}.property-list.advantages li:before{content:"✓";color:var(--success)}.property-list.disadvantages li:before{content:"⚠";color:var(--secondary)}.applications-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.application-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border-radius:var(--radius-md);transition:all var(--transition-normal)}.application-card:hover{background:var(--bg-card);transform:translate(5px)}.app-number{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:var(--bg-dark);border-radius:var(--radius-full);font-weight:700;font-size:.9rem;flex-shrink:0}.comparison-panel{overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;margin-top:var(--space-md)}.comparison-table th,.comparison-table td{padding:.8rem var(--space-md);text-align:left;border-bottom:1px solid var(--border)}.comparison-table th{background:var(--bg-elevated);color:var(--text-muted);font-weight:600;font-size:.85rem;text-transform:uppercase}.comparison-table tr:hover{background:var(--bg-elevated)}.comparison-table tr.selected{background:linear-gradient(90deg,var(--primary-alpha),transparent);border-left:3px solid var(--primary)}.comparison-table tr.selected td:first-child{color:var(--primary);font-weight:600}.subband-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.8rem;margin-top:var(--space-md)}.subband-item{background:var(--bg-elevated);padding:.6rem;border-radius:var(--radius-md);text-align:center;font-size:.8rem}.subband-item h4{color:var(--primary);margin-bottom:.4rem;font-size:.9rem}.subband-item img{max-width:100%;border-radius:var(--radius-sm);margin-bottom:.4rem}.freq-explanation{color:var(--text-muted);margin-top:var(--space-md);text-align:center}.wavelet-type-selector{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.wavelet-type-selector button{padding:.6rem var(--space-md);border:2px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:all var(--transition-normal);font-size:.85rem}.wavelet-type-selector button:hover{border-color:var(--primary);color:#fff}.wavelet-type-selector button.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--bg-dark);border-color:var(--primary);font-weight:600}@media (max-width: 900px){.properties-grid,.applications-grid{grid-template-columns:1fr}.wavelet-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}}.intro-view{padding-bottom:var(--space-lg)}.intro-hero{text-align:center;padding:var(--space-xl) var(--space-xl);display:flex;flex-direction:column;align-items:center;justify-content:center}.intro-hero h1{font-size:3rem;background:linear-gradient(135deg,var(--primary) 0%,var(--secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-md)}.intro-hero .subtitle{font-size:1.3rem;color:var(--text-muted);max-width:600px;margin:0 auto var(--space-xl)}.intro-buttons{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center}.intro-buttons .secondary{background:transparent;border:2px solid var(--border);color:var(--text-muted)}.intro-buttons .secondary:hover{border-color:var(--primary);color:var(--primary)}.fourier-view{padding-bottom:var(--space-xl)}.fourier-view button.active{background:var(--primary);color:var(--bg-dark)}.slide-fourier-theory-enhanced{height:100%;display:flex;flex-direction:column;padding:1.5rem 2rem}.slide-fourier-theory-enhanced .slide-header{margin-bottom:.75rem}.slide-fourier-theory-enhanced .slide-content{font-size:1.1rem;color:var(--text-muted);margin-bottom:1rem;text-align:center}.fourier-formulas-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;flex:1;min-height:0}.fourier-formulas-grid .formula-card{background:linear-gradient(145deg,#ffd93d14,#ffd93d08);border:1px solid rgba(255,217,61,.3);border-radius:12px;padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.fourier-formulas-grid .formula-card h4{margin:0 0 .5rem;font-size:.95rem;color:#ffd93d;font-weight:600}.fourier-formulas-grid .formula-card .math-formula{background:#0003;padding:.6rem 1rem;border-radius:8px;margin-bottom:.5rem}.fourier-formulas-grid .formula-card .formula-desc{margin:0;font-size:.8rem;color:#fff9;line-height:1.3}.fourier-formulas-grid .formula-card.euler{background:linear-gradient(145deg,#00d9ff14,#00d9ff08);border-color:#00d9ff4d}.fourier-formulas-grid .formula-card.euler h4{color:#00d9ff}.fourier-formulas-grid .formula-card.parseval{background:linear-gradient(145deg,#ff6b9d14,#ff6b9d08);border-color:#ff6b9d4d}.fourier-formulas-grid .formula-card.parseval h4{color:#ff6b9d}.slide-fourier-theory-enhanced .slide-points.compact{margin-top:.75rem;padding-left:1.5rem;display:flex;justify-content:center;gap:2rem;list-style:none}.slide-fourier-theory-enhanced .slide-points.compact li{font-size:.9rem;color:#ffffffb3;position:relative;padding-left:1rem}.slide-fourier-theory-enhanced .slide-points.compact li:before{content:"•";position:absolute;left:0;color:#ffd93d}.fourier-plots{display:flex;flex-direction:column;gap:.75rem;flex:1;min-height:0;padding:.25rem 0}.fourier-view .plot-container-with-overlay{position:relative;flex:1;min-height:0;display:flex;flex-direction:column}.fourier-view .plot-container-with-overlay canvas{width:100%;height:100%;min-height:140px;background:#050510;border-radius:8px;display:block}.fourier-view .plot-title-overlay{position:absolute;top:8px;left:50px;font-size:.95rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.9);pointer-events:none}.fourier-view .plot-title-overlay.cyan{color:#00d9ff}.fourier-view .plot-title-overlay.pink{color:#ff6b9d}.fourier-view .plot-axis-label{position:absolute;font-size:.85rem;font-weight:600;color:#ffffffbf;pointer-events:none}.fourier-view .plot-axis-label.y-label{top:50%;left:6px;transform:translateY(-50%);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.fourier-view .plot-axis-label.x-label{bottom:4px;right:15px}.fourier-view.fourier-compact{padding-bottom:0;display:flex;flex-direction:column;height:100%}.fourier-compact-layout{display:flex;flex:1;min-height:0;gap:.75rem}.fourier-side-controls{width:155px;flex-shrink:0;background:#141923e6;border-radius:8px;padding:.6rem;display:flex;flex-direction:column;gap:.4rem;align-self:flex-start;margin-top:.5rem;border:1px solid rgba(255,255,255,.08)}.fourier-side-controls h4{margin:0 0 .3rem;font-size:.75rem;color:#ffd93d;text-align:center;padding-bottom:.3rem;border-bottom:1px solid rgba(255,255,255,.1)}.spectrum-toggle{display:flex;gap:.3rem;margin-bottom:.5rem}.spectrum-toggle button{flex:1;padding:.4rem .3rem;font-size:.8rem;font-weight:600;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff9;cursor:pointer;transition:all .15s ease}.spectrum-toggle button:hover{background:#9d4edd33;border-color:#9d4edd66}.spectrum-toggle button.active{background:linear-gradient(135deg,#9d4edd4d,#c864ff33);border-color:#9d4edd;color:#c084fc}.fourier-view .plot-title-overlay.purple{color:#c084fc}.preset-buttons-vertical{display:flex;flex-direction:column;gap:.35rem}.preset-buttons-vertical button{padding:.4rem .5rem;font-size:.75rem;font-weight:500;text-align:left;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffd9;cursor:pointer;transition:all .15s ease}.preset-buttons-vertical button:hover{background:#00d9ff26;border-color:#00d9ff66;transform:translate(2px)}.preset-buttons-vertical button.active{background:linear-gradient(135deg,#00b4dc4d,#00d9ff26);border-color:#00d9ff;color:#00d9ff;font-weight:600;box-shadow:0 0 8px #00d9ff4d}.fourier-main-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.fourier-main-content .fourier-plots{flex:1;min-height:0}.fourier-equation-bar{flex-shrink:0;background:#00d9ff1a;border:1px solid rgba(0,217,255,.3);border-radius:6px;padding:.5rem 1rem;text-align:center}.fourier-equation-bar code{font-size:.95rem;color:#00d9ff;font-family:Fira Code,monospace;font-weight:500}.fourier-equation-bar .custom-input-row{display:flex;align-items:center;justify-content:center;gap:.5rem}.fourier-equation-bar .custom-input-row span{color:#ff6b9d;font-family:monospace;font-size:.9rem}.fourier-equation-bar .custom-input-row input{flex:1;max-width:350px;padding:.3rem .5rem;font-family:monospace;font-size:.85rem;background:#0000004d;border:1px solid rgba(255,107,157,.5);border-radius:4px;color:#ff6b9d}.fourier-equation-bar .custom-input-row button{padding:.3rem .5rem;font-size:.8rem}.fourier-view.fourier-compact .controls-panel{flex-shrink:0;margin:0;background:#141923cc;border-radius:8px}.fourier-view .controls-panel{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--bg-darker);border-radius:var(--radius-md)}.fourier-view .controls-panel h3{margin-bottom:var(--space-md);font-size:1rem;color:var(--text-muted)}.fourier-view .details-section{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width: 768px){.fourier-view .details-section{grid-template-columns:1fr}}.signal-comparison-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width: 768px){.signal-comparison-grid{grid-template-columns:1fr}}.signal-comparison-grid .plot-container{background:var(--bg-darker);border-radius:var(--radius-md);padding:var(--space-sm)}.signal-comparison-grid canvas{width:100%;height:auto}.filter-controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-lg);margin-bottom:var(--space-lg)}.filters-view .plot-container-with-overlay{position:relative;width:100%;height:200px;background:#050510;border-radius:8px;overflow:hidden}.filters-compact-layout .plot-container-with-overlay{height:auto;flex:1;min-height:100px}.filters-view .plot-container-with-overlay canvas{position:absolute;top:0;left:0;width:100%;height:100%;display:block}.filters-view .plot-title-overlay{position:absolute;top:6px;left:10px;font-size:.8rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.9);pointer-events:none;z-index:10}.filters-view .plot-title-overlay.white{color:#fff}.filters-view .plot-title-overlay.yellow{color:#ffd93d}.filters-view .plot-legend-overlay{position:absolute;top:6px;right:10px;background:#050510d9;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:4px 8px;display:flex;gap:10px;font-size:.7rem;pointer-events:none;z-index:10}.filters-view .plot-axis-label{position:absolute;font-size:.7rem;font-weight:600;color:#aac;pointer-events:none;z-index:10}.filters-view .plot-axis-label.y-label{top:50%;left:6px;transform:translateY(-50%) rotate(-90deg);transform-origin:center center}.filters-view .plot-axis-label.x-label{bottom:6px;right:10px}.filters-compact-layout{display:flex;flex-direction:column;gap:.5rem;height:100%;width:100%}.filters-top-row{display:flex;gap:.5rem;flex:.85;min-height:0}.filters-top-row .plot-container-with-overlay{flex:1;min-width:0;height:100%}.filters-bottom-row{display:flex;gap:.5rem;flex:1.15;min-height:0}.filters-bottom-row .plot-container-with-overlay{flex:1;min-width:0;height:100%}.filters-inline-controls{width:200px;flex-shrink:0;background:#141923f2;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;overflow-y:auto}.filters-inline-controls .controls-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.filters-inline-controls .controls-header h4{margin:0;color:#ff6b6b;font-size:.9rem}.filters-inline-controls .reset-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff9;font-size:1rem;padding:.2rem .4rem;cursor:pointer;transition:all .2s}.filters-inline-controls .reset-btn:hover{background:#ff6b6b33;border-color:#ff6b6b;color:#ff6b6b}.filters-inline-controls h4{margin:0;color:#ff6b6b;font-size:.95rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.filters-inline-controls .control-row{display:flex;flex-direction:column;gap:.3rem}.filters-inline-controls .control-row label{color:#ffffffd9;font-size:.8rem;font-weight:500}.filters-inline-controls .control-row label strong{color:#fa0}.filters-inline-controls .button-group.mini{display:flex;gap:.3rem}.filters-inline-controls .button-group.mini button{flex:1;padding:.4rem .5rem;font-size:.75rem;font-weight:500;border-radius:4px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#ffffffb3;cursor:pointer;transition:all .2s}.filters-inline-controls .button-group.mini button:hover{background:#ffffff1a}.filters-inline-controls .button-group.mini button.active{border-color:#00d4ff;background:#00d4ff33;color:#fff}.filters-inline-controls .button-group.mini button.active.success{border-color:#0f8;background:#0f83}.filters-inline-controls .button-group.mini button.active.danger{border-color:#ff6b9d;background:#ff6b9d33}.filters-inline-controls .button-group.mini button.active.bandpass{border-color:#9d4edd;background:#9d4edd33;color:#c084fc}.filters-inline-controls .order-buttons{display:flex;gap:.25rem}.filters-inline-controls .order-buttons button{flex:1;padding:.3rem .4rem;font-size:.75rem;font-weight:600;border-radius:4px;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:#ffffffb3;cursor:pointer;transition:all .2s}.filters-inline-controls .order-buttons button:hover{background:#ffaa0026;border-color:#fa06}.filters-inline-controls .order-buttons button.active{border-color:#fa0;background:#ffaa0040;color:#fa0}.filters-inline-controls select{width:100%;padding:.4rem;font-size:.8rem;border-radius:4px;border:1px solid rgba(255,255,255,.2);background:#1e2332f2;color:#fff;cursor:pointer}.filters-inline-controls select option{background:#1e2332;color:#fff;padding:.5rem}.filters-inline-controls input[type=range]{width:100%;height:6px;border-radius:3px;background:#fff3;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.filters-inline-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#fa0;cursor:pointer}.convolution-view{display:flex;flex-direction:column;height:100%;max-height:calc(100vh - 120px);overflow-y:auto;padding-bottom:var(--space-md)}.convolution-view .panel{margin-bottom:var(--space-md);padding:var(--space-md)}.convolution-view .panel h2{font-size:1.3rem;margin-bottom:var(--space-sm)}.convolution-view .panel h3{font-size:1.1rem;margin-bottom:var(--space-sm)}.convolution-view .info-box{margin:var(--space-sm) 0;padding:var(--space-sm) var(--space-md);font-size:.9rem}.convolution-view .math-block{padding:var(--space-sm);font-size:.95rem}.convolution-view .controls{gap:var(--space-sm)}.convolution-view .control-group{margin-bottom:var(--space-xs)}.convolution-view .kernel-display canvas{border:1px solid var(--border)}.convolution-view .plot-container{padding:var(--space-sm);margin:var(--space-sm) 0}.convolution-view .plot-container canvas{max-height:200px;width:100%}.convolution-view pre{background:var(--bg-darker);padding:var(--space-sm);border-radius:var(--radius-sm);margin:var(--space-sm) 0;line-height:1.4}.convolution-view.compact-mode{max-width:100%;height:100%;display:flex;flex-direction:column}.compact-conv-layout{display:flex;gap:1rem;height:100%;padding:.5rem}.compact-conv-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:.6rem;overflow-y:auto}.compact-conv-sidebar .compact-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.75rem}.compact-conv-sidebar h4{margin:0 0 .6rem;font-size:.9rem;color:#c9b1ff}.compact-control{margin-bottom:.6rem}.compact-control label{display:block;font-size:.75rem;color:#ffffffb3;margin-bottom:.25rem}.compact-control select,.compact-control input[type=range]{width:100%}.compact-control select{padding:.4rem;font-size:.8rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#fff}.compact-control select option{background:#1a1d24}.compact-buttons{display:flex;gap:.5rem}.compact-btn{flex:1;padding:.4rem .6rem;font-size:.8rem;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#ffffff0d;color:#fff;cursor:pointer;transition:all .2s}.compact-btn:hover:not(:disabled){background:#ffffff1a}.compact-btn.primary{background:#c9b1ff33;border-color:#c9b1ff66}.compact-btn:disabled{opacity:.5;cursor:not-allowed}.compact-kernel-canvas{width:100%;height:70px;background:#0a0a1a;border-radius:6px}.compact-kernel-wrapper{width:100%;height:70px}.kernel-formula-mini{font-size:.8rem;color:#fff9;text-align:center}.compact-conv-result{flex:1;display:flex;flex-direction:column;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.5rem;min-height:0}.compact-conv-result h4{margin:0 0 .5rem;font-size:.9rem;color:#c9b1ff}.compact-result-canvas{width:100%;height:100%;background:#050510;border-radius:8px;display:block}.compact-legend{display:flex;justify-content:center;gap:1.5rem;margin-top:.5rem;font-size:.75rem;color:#ffffffb3}.legend-item{display:flex;align-items:center;gap:.4rem}.legend-item .dot{width:10px;height:10px;border-radius:50%}.legend-item .dot.gray{background:#88a9}.legend-item .dot.green{background:#0f8}.plot-container-with-overlay{position:relative;flex:1;display:flex;flex-direction:column;min-height:280px}.plot-container-with-overlay canvas{width:100%;height:100%;background:#050510;border-radius:8px;display:block}.plot-title-overlay{position:absolute;top:8px;left:12px;font-size:.85rem;font-weight:600;color:#00d9ff;text-shadow:0 1px 3px rgba(0,0,0,.8);pointer-events:none}.plot-legend-overlay{position:absolute;top:8px;right:12px;background:#050510d9;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:6px 10px;display:flex;flex-direction:column;gap:4px;pointer-events:none}.legend-entry{display:flex;align-items:center;gap:8px;font-size:.7rem;color:#fffc}.legend-line{width:20px;height:3px;border-radius:1px}.legend-line.gray{background:#88a9}.legend-line.cyan{background:#00d9ff66}.legend-line.green{background:#0f8}.legend-line.orange{background:#fa0}.dot-product-overlay{position:absolute;bottom:12px;right:12px;background:#050510eb;border:1px solid rgba(255,215,0,.3);border-radius:8px;padding:4px;box-shadow:0 4px 20px #00000080;pointer-events:none;z-index:10}.dot-product-inline{background:#050510eb;border:1px solid rgba(255,215,0,.3);border-radius:8px;padding:4px;flex-shrink:0}.dot-product-inline canvas{display:block;border-radius:4px}.dot-product-overlay canvas{display:block;border-radius:4px}.frame-controls-integrated{display:flex;gap:1rem;padding:.6rem;background:#ffffff08;border-top:1px solid rgba(255,255,255,.08);border-radius:0 0 10px 10px;align-items:center;justify-content:space-between;height:160px;flex-shrink:0}.frame-controls-left{display:flex;flex-direction:column;gap:.5rem;width:280px;flex-shrink:0}.frame-controls{display:flex;flex-direction:column;gap:.5rem;padding:.6rem;background:#ffffff08;border-top:1px solid rgba(255,255,255,.08);border-radius:0 0 10px 10px}.frame-controls-row{display:flex;justify-content:center;gap:.4rem}.frame-btn{width:36px;height:32px;padding:0;font-size:1rem;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#ffffff0d;color:#fff;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.frame-btn:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff40}.frame-btn:disabled{opacity:.4;cursor:not-allowed}.frame-btn.play{width:44px;background:#00ff8826;border-color:#00ff884d;color:#0f8}.frame-btn.play:hover:not(:disabled){background:#00ff8840}.frame-btn.play.active{background:#fa03;border-color:#fa06;color:#fa0}.frame-btn.reset{background:#ff6b9d1a;border-color:#ff6b9d33;color:#ff6b9d}.frame-btn.reset:hover{background:#ff6b9d33}.position-slider{padding:0 .5rem}.position-slider input[type=range]{width:100%;height:6px;accent-color:#ffaa00}.frame-options{display:flex;justify-content:space-between;align-items:center;padding:0 .25rem;font-size:.75rem}.frame-option{display:flex;align-items:center;gap:.4rem;color:#ffffffb3;cursor:pointer}.frame-option input[type=checkbox]{accent-color:#c9b1ff}.speed-control{display:flex;align-items:center;gap:.4rem;color:#fff9}.speed-control input[type=range]{accent-color:#c9b1ff}.mode-toggle{display:flex;gap:var(--space-xs);margin-bottom:var(--space-md);background:var(--bg-darker);padding:var(--space-xs);border-radius:var(--radius-md);width:fit-content}.mode-toggle button{padding:var(--space-sm) var(--space-md);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.mode-toggle button.active{background:var(--primary);color:var(--bg-dark)}.mode-toggle button:hover:not(.active){background:var(--bg-elevated);color:var(--text-light)}.kernel-categories{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.kernel-category h4{color:var(--text-light);margin-bottom:var(--space-sm);font-size:.9rem}.kernel-buttons{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.kernel-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem}.kernel-btn:hover{border-color:var(--primary);color:var(--text-light)}.kernel-btn.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-color:var(--primary);color:var(--bg-dark)}.kernel-details{background:var(--bg-darker);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.kernel-description{color:var(--text-muted);margin-bottom:var(--space-md);font-style:italic}.kernel-matrix-display h4{color:var(--text-light);margin-bottom:var(--space-sm);font-size:.9rem}.kernel-matrix{display:inline-flex;flex-direction:column;gap:2px;background:var(--border);padding:2px;border-radius:var(--radius-sm)}.kernel-row{display:flex;gap:2px}.kernel-cell{width:60px;height:40px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.8rem;background:var(--bg-card);border-radius:2px}.kernel-cell.positive{background:#2ed57333;color:var(--success)}.kernel-cell.negative{background:#ff6b6b33;color:var(--secondary)}.kernel-cell.zero{background:var(--bg-elevated);color:var(--text-muted)}.kernel-with-scale{display:flex;align-items:center;gap:var(--space-md)}.kernel-scale{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono)}.scale-fraction{font-size:1.2rem;font-weight:600;color:var(--primary);background:#00d9ff1a;padding:.25rem .5rem;border-radius:var(--radius-sm)}.scale-times{font-size:1.1rem;color:var(--text-muted)}.custom-kernel-editor{background:var(--bg-darker);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.custom-kernel-editor>p{color:var(--text-muted);margin-bottom:var(--space-md)}.kernel-matrix.editable{background:var(--bg-card)}.kernel-cell-input{width:60px;height:40px;border:1px solid var(--border);border-radius:2px;background:var(--bg-elevated);color:var(--text-light);font-family:var(--font-mono);font-size:.85rem;text-align:center;transition:border-color var(--transition-fast)}.kernel-cell-input:focus{outline:none;border-color:var(--primary);background:var(--bg-dark)}.kernel-cell-input::-webkit-inner-spin-button{-webkit-appearance:none}.quick-presets{margin-top:var(--space-md);display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center}.quick-presets span{color:var(--text-muted);font-size:.85rem;margin-right:var(--space-sm)}.quick-presets button{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-muted);cursor:pointer;font-size:.8rem;transition:all var(--transition-fast)}.quick-presets button:hover{border-color:var(--primary);color:var(--text-light)}.kernel-size-selector{display:flex;gap:var(--space-xs);margin-top:var(--space-sm)}.size-btn{padding:var(--space-sm) var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.9rem;font-weight:500;min-width:60px}.size-btn:hover{border-color:var(--primary);color:var(--text-light)}.size-btn.active{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-color:var(--primary);color:var(--bg-dark);box-shadow:0 2px 8px #00d4ff4d}.control-group .hint{display:block;font-size:.75rem;color:var(--text-muted);margin-top:var(--space-xs);font-style:italic}.current-image{color:var(--text-muted);font-size:.9rem;margin-top:var(--space-md)}.comparison-toggle{margin-bottom:var(--space-md)}.comparison-toggle label{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-muted);cursor:pointer}.comparison-toggle input[type=checkbox]{accent-color:var(--primary)}.image-comparison{display:grid;gap:var(--space-lg)}.image-comparison.side-by-side{grid-template-columns:repeat(2,1fr)}.image-comparison.single{grid-template-columns:1fr;max-width:600px;margin:0 auto}.image-comparison .image-card{background:var(--bg-darker);padding:var(--space-md);border-radius:var(--radius-md);text-align:center}.image-comparison .image-card h4{color:var(--text-light);margin-bottom:var(--space-sm)}.image-comparison .image-card img{max-width:100%;height:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}.image-comparison .image-card p{color:var(--text-muted);font-size:.85rem;margin-top:var(--space-sm)}.explanation-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-md)}.explanation-card.blur{border-left-color:var(--primary)}.explanation-card.edge{border-left-color:var(--secondary)}.explanation-card.sharpen{border-left-color:var(--success)}.explanation-card.emboss{border-left-color:var(--purple)}.mini-kernel{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:120px;margin-top:var(--space-sm);background:var(--border);padding:2px;border-radius:var(--radius-sm)}.mini-kernel span{padding:var(--space-xs);background:var(--bg-card);text-align:center;font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted)}.kernels-view .math-block{text-align:center;margin:var(--space-md) 0}.kernels-view .math-label{display:block;color:var(--text-muted);font-size:.85rem;margin-top:var(--space-sm)}@media (max-width: 768px){.image-comparison.side-by-side,.explanation-cards{grid-template-columns:1fr}.kernel-cell,.kernel-cell-input{width:50px;height:35px;font-size:.75rem}}.kernels-view.compact-mode{width:100%;height:100%;display:flex;flex-direction:column;padding:var(--space-sm);box-sizing:border-box;gap:var(--space-sm)}.kernels-compact-header{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.kernels-compact-header .header-icon{font-size:1.3rem}.kernels-compact-header h1{font-size:1.2rem;color:var(--text-light);margin:0}.kernels-images-row{flex:1;display:flex;gap:var(--space-md);min-height:0}.kernel-image-card{flex:1;display:flex;flex-direction:column;align-items:center;background:var(--bg-darker);border-radius:var(--radius-md);padding:var(--space-xs);border:1px solid var(--border);min-width:0;overflow:hidden}.kernel-image-card .image-label{color:var(--text-light);font-size:.8rem;font-weight:600;margin-bottom:var(--space-xs);text-align:center;flex-shrink:0}.kernel-image-card img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-sm);flex:1;min-height:0}.kernels-bottom-toolbar{flex-shrink:0;background:var(--bg-darker);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--border);display:flex;justify-content:center}.toolbar-row{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);flex-wrap:wrap}.toolbar-item{display:flex;align-items:center;gap:var(--space-xs)}.toolbar-item label{color:var(--text-muted);font-size:.85rem;white-space:nowrap}.toolbar-item select{padding:6px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-light);font-size:.85rem;min-width:150px}.toolbar-item select option,.toolbar-item select optgroup{background:var(--bg-card);color:var(--text-light)}.toolbar-item.size-control{gap:var(--space-sm)}.toolbar-item.size-control input[type=range]{width:80px;accent-color:var(--primary)}.toolbar-matrix{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);min-width:180px;height:106px}.toolbar-matrix .scale-text{color:var(--primary);font-family:var(--font-mono);font-size:.8rem;font-weight:600}.kernel-table-mini{border-collapse:collapse;border:1px solid var(--border)}.kernel-table-mini td{width:22px;height:20px;text-align:center;vertical-align:middle;background:var(--bg-card);border:1px solid var(--border);font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);padding:2px;box-sizing:border-box}.kernel-table-mini td.positive{color:var(--success)}.kernel-table-mini td.negative{color:var(--danger)}.kernel-table-mini td.zero{color:var(--text-muted)}@media (max-width: 800px){.kernels-images-row{flex-direction:column}.toolbar-row{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.toolbar-item{justify-content:space-between}.toolbar-item select{flex:1;min-width:unset}.toolbar-matrix{margin-left:0;justify-content:center}}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#11182799;border-radius:var(--radius-md);color:var(--text-muted);gap:var(--space-sm);opacity:1;transition:opacity .15s ease-out;pointer-events:none}.kernel-image-card img{transition:opacity .2s ease-out}.error.compact{position:absolute;bottom:var(--space-sm);left:50%;transform:translate(-50%);background:var(--danger-bg);color:var(--danger);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.85rem}.kernels-view.explanation-only{height:100%;display:flex;flex-direction:column;padding:var(--space-sm);gap:var(--space-sm);overflow:hidden}.explanation-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);flex:1;min-height:0}.explanation-cards-grid.three-cols{grid-template-columns:repeat(3,1fr)}.explanation-cards-grid.six-cards{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}.explanation-cards-grid .explanation-card{display:flex;flex-direction:column;align-items:center;background:var(--bg-darker);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);border-left:3px solid var(--primary);overflow:hidden;min-height:0}.explanation-cards-grid .explanation-card h4{color:var(--text-light);margin:0 0 .2rem;font-size:.95rem;align-self:flex-start;width:100%}.explanation-cards-grid .explanation-card p{color:var(--text-muted);font-size:.85rem;line-height:1.35;margin-bottom:0;align-self:flex-start;width:100%}.kernel-example{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;flex:1;margin-top:var(--space-sm);min-height:0}.kernels-row{display:flex;flex-wrap:wrap;gap:var(--space-lg);justify-content:center;align-items:center;margin-top:var(--space-sm)}.kernels-row .kernel-example{flex-direction:column;gap:4px;flex:0 0 auto;margin-top:0}.kernels-row .kernel-table{flex-shrink:0}@media (max-width: 1200px){.kernel-example{flex-direction:column;gap:4px}.explanation-cards-grid.six-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 800px){.explanation-cards-grid.six-cards{grid-template-columns:1fr}}.kernel-example .scale-label{color:var(--primary);font-family:var(--font-mono);font-size:.9rem;white-space:nowrap}.kernel-table{border-collapse:collapse;border:1px solid var(--border);border-radius:var(--radius-sm)}.kernel-table td{width:36px;height:30px;text-align:center;vertical-align:middle;background:var(--bg-card);border:1px solid var(--border);font-family:var(--font-mono);font-size:.9rem;color:var(--text-muted)}.kernel-table.four td{width:32px;height:26px;font-size:.85rem}.kernel-table.five td{width:28px;height:24px;font-size:.75rem}.kernels-view.explanation-only .wavelet-connection-box{background:linear-gradient(135deg,#00d4ff1a,#00ff881a);border:1px solid rgba(0,212,255,.3);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md);flex-shrink:0}.kernels-view.explanation-only .wavelet-connection-box h4{color:var(--primary);margin:0 0 .3rem;font-size:.95rem}.kernels-view.explanation-only .wavelet-connection-box p{color:var(--text-muted);font-size:.9rem;line-height:1.4;margin:0}.kernels-view.explanation-only .wavelet-connection-box strong{color:var(--text-light)}.kernel-matrix.mini{display:grid;gap:1px;background:var(--border);padding:1px;border-radius:3px}.kernel-matrix.mini .kernel-row{display:contents}.wavelet-playground-v2{display:flex;flex-direction:row;width:100%;height:100%;box-sizing:border-box;overflow:hidden}.wavelet-playground-v2 .playground-top-row{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.wavelet-playground-v2 .playground-main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;gap:.25rem;padding:.4rem}.wavelet-playground-v2 .formula-bar{text-align:center;padding:.3rem .75rem;background:#ffffff0d;border-radius:6px;font-size:1.1rem;flex-shrink:0}.wavelet-playground-v2 .param-badges{display:flex;justify-content:center;gap:1rem;flex-shrink:0}.wavelet-playground-v2 .param-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .5rem;border-radius:5px;font-size:.8rem;font-weight:500}.wavelet-playground-v2 .param-badge.scale{background:#00d9ff26;border:1px solid rgba(0,217,255,.4);color:#00d9ff}.wavelet-playground-v2 .param-badge.shift{background:#ffaa0026;border:1px solid rgba(255,170,0,.4);color:#fa0}.wavelet-playground-v2 .param-badge small{font-size:.65rem;color:#888;font-weight:400}.wavelet-playground-v2 .plot-container{flex:1;position:relative;min-height:100px;background:#050510;border-radius:8px;overflow:hidden}.wavelet-playground-v2 .plot-container canvas{display:block;width:100%;height:100%}.wavelet-playground-v2 .plot-title-overlay{position:absolute;top:.5rem;right:.75rem;font-size:.9rem;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.8)}.wavelet-playground-v2 .playground-sidebar{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:.4rem;overflow-y:auto;padding:.4rem;background:#ffffff05;border-left:1px solid #333}.wavelet-playground-v2 .sidebar-section{background:#ffffff0d;border-radius:6px;overflow:hidden;flex-shrink:0;display:flex;flex-direction:column}.wavelet-playground-v2 .section-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;background:#ffffff0d;font-weight:600;font-size:.85rem;color:#fff}.wavelet-playground-v2 .section-header.clickable{cursor:pointer}.wavelet-playground-v2 .section-header.clickable:hover{background:#ffffff14}.wavelet-playground-v2 .toggle-icon{font-size:.7rem;color:#888}.wavelet-playground-v2 .section-content{padding:.5rem .6rem;background:transparent;flex:1;display:flex;flex-direction:column}.wavelet-playground-v2 .wavelet-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;margin-bottom:.5rem}.wavelet-playground-v2 .wavelet-btn{padding:.35rem .4rem;border:2px solid transparent;border-radius:5px;background:#ffffff14;color:#aaa;font-size:.75rem;cursor:pointer;transition:all .15s}.wavelet-playground-v2 .wavelet-btn:hover{background:#ffffff1f}.wavelet-playground-v2 .wavelet-btn.active{background:#ffffff26;font-weight:600}.wavelet-playground-v2 .wavelet-btn[data-wavelet=haar].active{border-color:#00d9ff;color:#00d9ff}.wavelet-playground-v2 .wavelet-btn[data-wavelet=morlet].active{border-color:#ff6b9d;color:#ff6b9d}.wavelet-playground-v2 .wavelet-btn[data-wavelet=mexican_hat].active{border-color:#50fa7b;color:#50fa7b}.wavelet-playground-v2 .wavelet-btn[data-wavelet=daubechies].active{border-color:#bd93f9;color:#bd93f9}.wavelet-playground-v2 .wavelet-desc{font-size:.75rem;color:#aaa;margin:.3rem 0;line-height:1.4}.wavelet-playground-v2 .wavelet-equation{font-size:.75rem;background:#0000004d;padding:.35rem .5rem;border-radius:5px;text-align:center;margin-top:auto;overflow-x:auto}.wavelet-playground-v2 .control-row{margin-bottom:.4rem}.wavelet-playground-v2 .control-row:last-child{margin-bottom:0}.wavelet-playground-v2 .control-row label{display:block;font-size:.7rem;color:#ccc;margin-bottom:.15rem}.wavelet-playground-v2 .control-row input[type=range]{width:100%;height:5px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:3px;outline:none}.wavelet-playground-v2 .control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;background:#00d9ff;border-radius:50%;cursor:pointer}.wavelet-playground-v2 .control-row input[type=range]::-moz-range-thumb{width:12px;height:12px;background:#00d9ff;border-radius:50%;cursor:pointer;border:none}.wavelet-playground-v2 .slider-hint{font-size:.6rem;color:#666;font-style:italic;margin-top:.15rem}.wavelet-playground-v2 .checkbox-row{display:flex;align-items:center;gap:.3rem;font-size:.7rem;color:#aaa;cursor:pointer;padding:.2rem 0}.wavelet-playground-v2 .checkbox-row input[type=checkbox]{accent-color:#00d9ff;width:12px;height:12px}.wavelet-playground-v2 .animation-row{display:flex;gap:.3rem}.wavelet-playground-v2 .animation-row select{flex:1;padding:.35rem .5rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#1a1a2e;color:#fff;font-size:.7rem;cursor:pointer}.wavelet-playground-v2 .animation-row select option{background:#1a1a2e;color:#fff}.wavelet-playground-v2 .anim-btn{padding:.35rem .6rem;border:none;border-radius:4px;font-size:.7rem;cursor:pointer;transition:all .15s}.wavelet-playground-v2 .anim-btn.reset{background:#ffffff1a;color:#aaa}.wavelet-playground-v2 .anim-btn.reset:hover{background:#ffffff26;color:#fff}.wavelet-playground-v2 .anim-btn.play{background:#00d9ff;color:#000}.wavelet-playground-v2 .anim-btn.play:hover{background:#00c4e8}.wavelet-playground-v2 .anim-btn.stop{background:#ff6b6b;color:#fff}.wavelet-playground-v2 .anim-btn.stop:hover{background:#ff5252}.wavelet-playground-v2 .theory-content{font-size:.95rem;flex:1;display:flex;flex-direction:column}.wavelet-playground-v2 .theory-item{margin-bottom:.75rem}.wavelet-playground-v2 .theory-item h5{font-size:1rem;margin:0 0 .3rem}.wavelet-playground-v2 .theory-item p{margin:.2rem 0;color:#bbb;line-height:1.5;font-size:.95rem}.wavelet-playground-v2 .theory-formula{background:#0000004d;padding:.5rem .6rem;border-radius:6px;text-align:center;font-size:.9rem;margin-top:auto;overflow-x:auto}.wavelet-playground-v2 .explanation-section{background:#ffffff08;flex:1}.wavelet-playground-v2 .explanation-section .section-content{padding:.75rem;flex:1}.wavelet-playground-v2 .playground-controls-bar{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1.5rem;padding:.4rem 1rem;background:#ffffff0d;border-top:1px solid #333;flex-wrap:nowrap;flex-shrink:0;font-size:.85rem}.wavelet-playground-v2 .playground-controls-bar .control-group{display:flex;flex-direction:row;align-items:center;gap:.5rem}.wavelet-playground-v2 .playground-controls-bar .control-group label{font-size:.75rem;color:#ccc;white-space:nowrap}.wavelet-playground-v2 .playground-controls-bar .control-group input[type=range]{width:100px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff26;border-radius:3px;outline:none}.wavelet-playground-v2 .playground-controls-bar .control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#00d9ff;border-radius:50%;cursor:pointer}.wavelet-playground-v2 .playground-controls-bar .slider-hint{font-size:.65rem;color:#888;min-width:50px}.wavelet-playground-v2 .playground-controls-bar .checkbox-control{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:#aaa;cursor:pointer}.wavelet-playground-v2 .playground-controls-bar .checkbox-control input[type=checkbox]{accent-color:#00d9ff;width:12px;height:12px}.wavelet-playground-v2 .playground-controls-bar .animation-controls{display:flex;flex-direction:row;gap:.4rem;align-items:center}.wavelet-playground-v2 .playground-controls-bar .animation-controls select{padding:.2rem .4rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#1a1a2e;color:#fff;font-size:.7rem;cursor:pointer}.wavelet-playground-v2 .playground-controls-bar .anim-btn{padding:.25rem .5rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .15s}.wavelet-playground-v2 .playground-controls-bar .anim-btn.reset{background:#ffffff1a;color:#aaa}.wavelet-playground-v2 .playground-controls-bar .anim-btn.reset:hover{background:#ffffff26;color:#fff}.wavelet-playground-v2 .playground-controls-bar .anim-btn.play{background:#00d9ff;color:#000}.wavelet-playground-v2 .playground-controls-bar .anim-btn.play:hover{background:#00c4e8}.wavelet-playground-v2 .playground-controls-bar .anim-btn.stop{background:#ff6b6b;color:#fff}.wavelet-playground-v2 .playground-controls-bar .anim-btn.stop:hover{background:#ff5252}.wavelet-playground-v2 .reset-btn{width:100%;padding:.5rem;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#aaa;font-size:.8rem;cursor:pointer;transition:all .15s;margin-top:auto}.wavelet-playground-v2 .reset-btn:hover{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.wavelet-playground{display:flex;flex-direction:column}.wavelet-playground .playground-header{text-align:center;padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm)}.wavelet-playground .playground-header h2{color:var(--primary);margin-bottom:var(--space-xs);font-size:1.5rem}.wavelet-playground .playground-header .subtitle{color:var(--text-muted);font-size:.95rem;margin:0}.decompose-view-v2{display:flex;gap:2rem;height:100%;min-height:550px;padding:1rem}.decompose-view-v2.compact{min-height:450px;padding:.5rem;gap:1.5rem}.decompose-main{flex:1;display:flex;flex-direction:column;gap:1rem;min-width:0}.decompose-header h3{color:var(--primary, #00d4ff);margin:0;font-size:1.2rem;text-align:center}.decompose-visuals{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.visual-panel{text-align:center}.visual-panel h4{margin:0 0 .5rem;color:#fffc;font-size:.9rem;font-weight:500}.visual-panel canvas{border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#0a0a1a}.visual-panel.main canvas{border-color:var(--primary, #00d4ff);box-shadow:0 0 20px #00d4ff33}.visual-arrow{font-size:2rem;color:var(--primary, #00d4ff);opacity:.7}.decompose-formula{text-align:center;padding:.5rem;background:#00d4ff0d;border-radius:8px;border:1px solid rgba(0,212,255,.2)}.energy-bars{padding:1rem;background:#ffffff08;border-radius:8px}.energy-bars h4{margin:0 0 .5rem;color:#fffc;font-size:.9rem}.energy-bar-container{display:flex;height:30px;border-radius:6px;overflow:hidden;background:#0000004d}.energy-segment{display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);transition:width .3s ease}.energy-segment.ll{background:linear-gradient(135deg,#00d4ff,#09c)}.energy-segment.lh{background:linear-gradient(135deg,#ff9f43,#cc7a30)}.energy-segment.hl{background:linear-gradient(135deg,#c9b1ff,#9a7acc)}.energy-segment.hh{background:linear-gradient(135deg,#ff6b9d,#cc5580)}.energy-note{margin:.5rem 0 0;color:#fff9;font-size:.85rem;text-align:center}.decompose-sidebar{width:250px;flex-shrink:0;display:flex;flex-direction:column;gap:1rem;background:#ffffff08;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.decompose-sidebar .sidebar-section{display:flex;flex-direction:column;gap:.5rem}.decompose-sidebar .sidebar-section label{color:#ffffffb3;font-size:.85rem;font-weight:500}.decompose-sidebar .sidebar-section select{padding:.5rem;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#0000004d;color:#fff;font-size:.9rem}.decompose-sidebar .sidebar-section input[type=range]{width:100%;accent-color:var(--primary, #00d4ff)}.band-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.band-btn{padding:.5rem;border-radius:6px;border:2px solid rgba(255,255,255,.3);background:transparent;color:#fff;font-weight:700;cursor:pointer;transition:all .2s ease}.band-btn:hover{background:#ffffff1a}.band-btn.active{background:#ffffff26;transform:scale(1.05)}.band-btn[data-band=ll]{border-color:#00d4ff}.band-btn[data-band=ll].active{background:#00d4ff4d;box-shadow:0 0 10px #00d4ff80}.band-btn[data-band=lh]{border-color:#ff9f43}.band-btn[data-band=lh].active{background:#ff9f434d;box-shadow:0 0 10px #ff9f4380}.band-btn[data-band=hl]{border-color:#c9b1ff}.band-btn[data-band=hl].active{background:#c9b1ff4d;box-shadow:0 0 10px #c9b1ff80}.band-btn[data-band=hh]{border-color:#ff6b9d}.band-btn[data-band=hh].active{background:#ff6b9d4d;box-shadow:0 0 10px #ff6b9d80}.sidebar-legend{padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-legend h4{margin:0 0 .5rem;color:#fffc;font-size:.85rem}.legend-item{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.8rem;color:#ffffffb3}.color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.color-dot.ll{background:#00d4ff}.color-dot.lh{background:#ff9f43}.color-dot.hl{background:#c9b1ff}.color-dot.hh{background:#ff6b9d}.sidebar-info{padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-info h4{margin:0 0 .5rem;color:var(--primary, #00d4ff);font-size:.85rem}.sidebar-info p{margin:0;color:#fff9;font-size:.8rem;line-height:1.4}.decompose-view-v2.compact .decompose-sidebar{width:220px}.decompose-view-v2.compact .visual-panel canvas{max-width:150px;max-height:150px}.decompose-view-v2.compact .visual-panel.main canvas{max-width:250px;max-height:250px}@media (max-width: 900px){.decompose-view-v2{flex-direction:column}.decompose-sidebar{width:100%;flex-direction:row;flex-wrap:wrap}}.decompose-view .level-selector{display:flex;gap:var(--space-sm);flex-wrap:wrap}.decompose-view .level-selector button{padding:.5rem var(--space-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all var(--transition-normal)}.decompose-view .level-selector button.active,.decompose-view .level-selector button:hover{background:var(--primary);color:var(--bg-dark);border-color:var(--primary)}.denoise-view .noise-controls{display:flex;gap:var(--space-md);flex-wrap:wrap;margin-bottom:var(--space-lg)}.denoise-theory-view{width:100%;height:100%;display:flex;flex-direction:column;padding:1.5rem 2rem;overflow:hidden;box-sizing:border-box}.denoise-theory-view.compact{padding:1rem 1.5rem}.denoise-theory-content{display:flex;flex-direction:column;gap:1.25rem;height:100%;justify-content:center}.denoise-theory-view .theory-section{background:#ffffff08;border-radius:12px;padding:1.25rem 1.5rem;flex-shrink:0}.denoise-theory-view .theory-section h2{margin:0 0 .75rem;font-size:1.5rem;color:#00d4ff}.denoise-theory-view .theory-section h3{margin:0 0 .75rem;font-size:1.2rem;color:#ccc}.denoise-theory-view .info-box{background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:8px;padding:.85rem 1.25rem;margin-bottom:1rem}.denoise-theory-view .info-box p{margin:0;font-size:1.1rem;line-height:1.6;color:#ddd}.denoise-theory-view .math-formulas{display:flex;gap:1.5rem}.denoise-theory-view .formula-row{display:flex;align-items:center;gap:1rem;padding:.6rem 1rem;background:#0000004d;border-radius:8px;flex:1}.denoise-theory-view .formula-label{font-size:1rem;color:#aaa;white-space:nowrap;font-weight:500}.denoise-theory-view .formula-math{flex:1}.denoise-theory-view .formula-math .katex{font-size:1.15rem}.denoise-theory-view .threshold-comparison{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.denoise-theory-view .threshold-card{background:#0000004d;border-radius:10px;padding:1rem 1.25rem;border:2px solid transparent}.denoise-theory-view .threshold-card.soft{border-color:#0f86}.denoise-theory-view .threshold-card.hard{border-color:#fa06}.denoise-theory-view .threshold-card .card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.denoise-theory-view .threshold-card h3{margin:0;font-size:1.2rem}.denoise-theory-view .threshold-card.soft h3{color:#0f8}.denoise-theory-view .threshold-card.hard h3{color:#fa0}.denoise-theory-view .threshold-card p{margin:0;font-size:1.05rem;line-height:1.5;color:#bbb}.denoise-theory-view .threshold-visual{flex-shrink:0}.denoise-theory-view .threshold-graph{width:120px;height:80px}.denoise-theory-view .process-section{padding:1rem 1.5rem}.denoise-theory-view .process-steps{display:flex;align-items:center;justify-content:center;gap:1.25rem}.denoise-theory-view .step{display:flex;align-items:center;gap:.75rem;background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:8px;padding:.75rem 1.5rem}.denoise-theory-view .step-num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#00d4ff;color:#000;border-radius:50%;font-weight:700;font-size:.95rem}.denoise-theory-view .step-text{font-size:1.1rem;color:#ddd}.denoise-theory-view .step-arrow{font-size:1.5rem;color:#666}.denoise-practical-view{width:100%;height:100%;display:flex;flex-direction:column;padding:.75rem;gap:.75rem;overflow:hidden;box-sizing:border-box}.denoise-controls-row{display:flex;align-items:flex-end;gap:1rem;padding:.75rem 1rem;background:#ffffff08;border-radius:10px;flex-shrink:0;flex-wrap:wrap}.denoise-controls-row .control-group{display:flex;flex-direction:column;gap:.25rem;min-width:100px}.denoise-controls-row .control-group label{font-size:.8rem;color:#888;text-transform:uppercase}.denoise-controls-row .control-group select,.denoise-controls-row .control-group input[type=range]{padding:.4rem .5rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:.9rem}.denoise-controls-row .control-group input[type=range]{width:80px;padding:0}.denoise-btn{padding:.5rem 1rem;background:#00d4ff33;border:1px solid #00d4ff;border-radius:6px;color:#00d4ff;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:all .2s ease}.denoise-btn:hover{background:#00d4ff4d}.denoise-btn.loading{opacity:.7;animation:pulse-btn 1s ease-in-out infinite}@keyframes pulse-btn{0%,to{opacity:.7}50%{opacity:.4}}.denoise-results{flex:1;display:flex;flex-direction:column;gap:.75rem;min-height:0;transition:opacity .2s ease}.denoise-results.loading{opacity:.5;pointer-events:none}.denoise-images{flex:1;display:flex;gap:1rem;min-height:300px}.denoise-image-card{flex:1;display:flex;flex-direction:column;background:#ffffff08;border-radius:10px;padding:.5rem;min-width:0;overflow:hidden}.denoise-image-card h4{margin:0 0 .4rem;font-size:.9rem;color:#ccc;text-align:center;flex-shrink:0}.denoise-image-card .img-wrapper{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.denoise-image-card img{width:100%;height:100%;object-fit:contain;border-radius:6px}.denoise-image-card .img-metric{margin-top:.4rem;padding:.3rem .5rem;background:#0000004d;border-radius:4px;font-size:.8rem;color:#aaa;text-align:center}.denoise-image-card .img-metric.success{background:#00ff8826;color:#0f8}.denoise-stats{display:flex;gap:1rem;flex-shrink:0}.denoise-stats .stat-item{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.6rem 1rem;background:#ffffff08;border-radius:8px}.denoise-stats .stat-label{font-size:.85rem;color:#888}.denoise-stats .stat-value{font-size:1.1rem;font-weight:700;color:#00d4ff}.denoise-stats .stat-item.success .stat-value{color:#0f8}.compare-view-compact{display:flex;flex-direction:column;height:100%;max-height:calc(100vh - 60px);padding:10px 20px;overflow:hidden}.compare-header{display:flex;justify-content:center;align-items:center;margin-bottom:8px}.compare-header h2{margin:0;font-size:1.5rem;color:gold}.info-tips-row{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px 16px;background:#ffffff0a;border-radius:10px}.info-section{display:flex;gap:30px;align-items:center;justify-content:center;flex-wrap:wrap}.info-section .info-col{font-size:1.05rem;color:#ddd}.tips-section{display:flex;gap:30px;justify-content:center;flex-wrap:wrap}.tips-section span{font-size:1rem;color:#aaa}.comparison-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0;position:relative;width:100%}.loading-overlay-inline{display:flex;align-items:center;gap:12px;padding:20px;color:gold}.loading-overlay-inline .spinner{width:24px;height:24px;border:3px solid rgba(255,215,0,.3);border-top-color:gold;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.comparison-images{display:flex;gap:20px;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .2s}.comparison-images.loading{opacity:.6;pointer-events:none}.comparison-images .comparison-card{background:#0000004d;border-radius:8px;overflow:hidden;border:2px solid transparent;display:flex;flex-direction:column;height:100%;flex:1;min-width:0}.comparison-images .comparison-card.dct{border-color:#ff9f4380}.comparison-images .comparison-card.wavelet{border-color:#00d4ff80}.comparison-images .card-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff0d;font-weight:600;font-size:.95rem;flex-shrink:0}.comparison-images .comparison-card.dct .card-header{color:#ff9f43}.comparison-images .comparison-card.wavelet .card-header{color:#00d4ff}.comparison-images .metric-inline{font-size:.85rem;background:#0000004d;padding:2px 8px;border-radius:4px}.comparison-images img{display:block;width:100%;height:100%;object-fit:contain;flex:1;min-height:0}.verdict-bar{margin-top:12px;padding:8px 20px;border-radius:6px;font-weight:600;font-size:1rem}.verdict-bar.wavelet-wins{background:#00d4ff33;color:#00d4ff;border:1px solid rgba(0,212,255,.4)}.verdict-bar.dct-wins{background:#ff9f4333;color:#ff9f43;border:1px solid rgba(255,159,67,.4)}.controls-bar{display:flex;align-items:center;gap:20px;padding:12px 16px;background:#ffffff0d;border-radius:8px;margin-top:10px;flex-wrap:wrap}.controls-bar .control-item{display:flex;align-items:center;gap:8px}.controls-bar label{font-size:.85rem;color:#aaa;white-space:nowrap}.controls-bar select{padding:6px 10px;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;font-size:.85rem}.controls-bar input[type=range]{width:100px;accent-color:#ffd700}.controls-bar .run-btn{padding:8px 16px;background:linear-gradient(135deg,gold,#ff9f43);border:none;border-radius:6px;color:#000;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.controls-bar .run-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 15px #ffd7004d}.controls-bar .run-btn:disabled{opacity:.5;cursor:not-allowed}.controls-bar .run-btn.loading{animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.error-message.compact{padding:8px 12px;background:#ff00001a;border:1px solid rgba(255,0,0,.3);border-radius:6px;color:#ff6b6b;font-size:.85rem;margin-bottom:10px}
