/* Wave Interference Simulator — 1D superposition + 2D ripple tank */
.tool-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.tool-panel { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-lg); }
.panel-title { font-family: var(--font-display); font-size: var(--fs-base); color: var(--color-primary); margin: 0 0 var(--space-md); text-transform: uppercase; letter-spacing: 0.05em; }

.input-group { margin-bottom: var(--space-md); }
.input-label { display: block; font-size: var(--fs-sm); color: var(--color-text-muted); margin-bottom: var(--space-xs); font-family: var(--font-mono); }
.input-field { width: 100%; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text); font-family: var(--font-mono); font-size: var(--fs-base); padding: var(--space-sm) var(--space-md); box-sizing: border-box; transition: border-color 0.2s; }
.input-field:focus { outline: none; border-color: var(--color-primary); box-shadow: var(--glow-sm); }
.input-with-unit { display: flex; gap: var(--space-xs); align-items: stretch; }
.input-with-unit .input-field { flex: 1; }
.unit-badge { display: flex; align-items: center; padding: 0 var(--space-md); background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-secondary); font-weight: 600; min-width: 3rem; justify-content: center; }

.mode-tabs { display: flex; gap: var(--space-xs); margin-bottom: var(--space-md); }
.mode-tab { flex: 1; padding: var(--space-xs) var(--space-sm); background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text-muted); font-family: var(--font-mono); font-size: var(--fs-sm); cursor: pointer; transition: all 0.2s; }
.mode-tab:hover { color: var(--color-primary); border-color: var(--color-primary); }
.mode-tab.active { background: color-mix(in srgb, var(--color-primary) 12%, transparent); color: var(--color-primary); border-color: var(--color-primary); box-shadow: var(--glow-sm); }

/* Two-wave grouping (Wave 1 vs Wave 2) */
.wave-group { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-md); margin-bottom: var(--space-md); }
.wave-group__title { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: var(--space-sm); font-family: var(--font-mono); display: flex; align-items: center; gap: var(--space-xs); }
.wave-group__title .swatch { display: inline-block; width: 14px; height: 3px; border-radius: 1px; }
.wave-group.wave-1 .swatch { background: #00e5ff; }
.wave-group.wave-2 .swatch { background: #ff4488; }

.slider-row { margin-top: var(--space-xs); }
.slider { width: 100%; accent-color: var(--color-primary); cursor: pointer; }
.slider-with-input { display: flex; gap: var(--space-xs); align-items: center; }
.slider-with-input .slider { flex: 1; }
.slider-with-input .small-input { width: 80px; }

.warning-note { margin-top: var(--space-md); padding: var(--space-sm) var(--space-md); background: color-mix(in srgb, #ffe000 10%, transparent); border: 1px solid #ffe000; border-radius: var(--radius-md); font-family: var(--font-mono); font-size: var(--fs-sm); color: #ffe000; line-height: 1.6; }

.presets-section { margin-top: var(--space-md); }
.presets-label { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: var(--space-xs); font-family: var(--font-mono); }
.presets-list { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.preset-btn { padding: var(--space-xs) var(--space-sm); border: 1px solid var(--color-border); border-radius: var(--radius-full); background: var(--color-bg); color: var(--color-text); font-family: var(--font-mono); font-size: var(--fs-xs); cursor: pointer; transition: all 0.2s; }
.preset-btn:hover { border-color: var(--color-primary); color: var(--color-primary); box-shadow: var(--glow-sm); }

.result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm); margin-bottom: var(--space-md); }
.result-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); }
.result-card__label { font-size: var(--fs-xs); color: var(--color-text-muted); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; }
.result-card__value { font-family: var(--font-mono); font-size: var(--fs-base); color: var(--color-secondary); font-weight: 600; margin-top: 2px; word-break: break-all; }

.zone-badge { display: inline-block; padding: var(--space-xs) var(--space-md); border-radius: var(--radius-full); font-family: var(--font-mono); font-size: var(--fs-sm); font-weight: 600; margin: 0 auto var(--space-md); text-align: center; border: 1px solid currentColor; }
.s-constructive { background: color-mix(in srgb, #00ff41 15%, transparent); color: #00ff41; }
.s-partial-c    { background: color-mix(in srgb, #00e5ff 15%, transparent); color: #00e5ff; }
.s-partial      { background: color-mix(in srgb, #ffe000 15%, transparent); color: #ffe000; }
.s-partial-d    { background: color-mix(in srgb, #ff4488 15%, transparent); color: #ff4488; }
.s-destructive  { background: color-mix(in srgb, #cc66ff 15%, transparent); color: #cc66ff; }

.formula-box { background: var(--color-bg); border: 1px solid var(--color-border); border-left: 3px solid var(--color-primary); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); margin-bottom: var(--space-md); }
.formula-title { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: var(--space-xs); }
.formula-text { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text); margin: 2px 0; word-break: break-word; }
.formula-calc { color: var(--color-secondary); }

/* Visualization panel */
.viz-wrap { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-md); margin-top: var(--space-lg); }
.viz-header { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.viz-title { font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); }
.viz-status { font-size: var(--fs-xs); color: var(--color-text-muted); font-family: var(--font-mono); }
.viz-controls { display: inline-flex; gap: var(--space-xs); align-items: center; }
.anim-btn { padding: var(--space-xs) var(--space-md); background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text); font-family: var(--font-mono); font-size: var(--fs-sm); cursor: pointer; transition: all 0.2s; }
.anim-btn:hover { color: var(--color-primary); border-color: var(--color-primary); }

.viz-canvas-wrap { display: flex; justify-content: center; }
.plot-1d { width: 100%; max-width: 600px; height: auto; display: block; }
.plot-2d { display: block; max-width: 320px; width: 100%; height: auto; border: 1px solid var(--color-border); border-radius: var(--radius-md); image-rendering: pixelated; }

.plot-grid { stroke: color-mix(in srgb, var(--color-border) 50%, transparent); stroke-width: 1; }
.plot-zero { stroke: color-mix(in srgb, var(--color-text-muted) 70%, transparent); stroke-width: 1; stroke-dasharray: 3 3; }
.plot-axis-title { fill: var(--color-text); font-family: var(--font-mono); font-size: 11px; }
.curve-w1  { stroke: #00e5ff; stroke-width: 1.5; opacity: 0.85; }
.curve-w2  { stroke: #ff4488; stroke-width: 1.5; opacity: 0.85; }
.curve-sum { stroke: #00ff41; stroke-width: 2.5; }

.legend-row { display: flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; margin-top: var(--space-xs); font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--color-text-muted); }
.legend-item { display: inline-flex; align-items: center; gap: 4px; }
.legend-swatch { display: inline-block; width: 18px; height: 3px; border-radius: 1px; }
.legend-swatch.curve-w1  { background: #00e5ff; }
.legend-swatch.curve-w2  { background: #ff4488; }
.legend-swatch.curve-sum { background: #00ff41; height: 4px; }

.content-section { max-width: 800px; margin: 0 auto var(--space-lg); color: var(--color-text); line-height: 1.7; }
.content-section h3 { color: var(--color-secondary); font-family: var(--font-display); margin-top: var(--space-lg); margin-bottom: var(--space-xs); font-size: var(--fs-md); }
.content-section p { margin-bottom: var(--space-sm); }

.faq-list { max-width: 800px; margin: 0 auto; }
.faq-item { border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: var(--space-sm); overflow: hidden; }
.faq-question { padding: var(--space-md); cursor: pointer; font-weight: 600; list-style: none; display: flex; justify-content: space-between; align-items: center; color: var(--color-text-bright); }
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after { content: '+'; color: var(--color-primary); font-size: 1.3em; font-weight: 700; }
details[open] .faq-question::after { content: '−'; }
.faq-answer { padding: 0 var(--space-md) var(--space-md); color: var(--color-text-muted); line-height: 1.75; border-top: 1px solid var(--color-border); padding-top: var(--space-sm); }

.related-tools-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); max-width: 800px; margin: 0 auto; }
.related-tool-card { display: block; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-md); text-decoration: none; transition: border-color 0.2s, transform 0.2s; text-align: left; }
.related-tool-card:hover { border-color: var(--color-primary); transform: translateY(-2px); }
.related-tool-card__title { font-family: var(--font-display); font-size: var(--fs-sm); color: var(--color-primary); margin-bottom: var(--space-xs); }
.related-tool-card__desc { font-size: var(--fs-xs); color: var(--color-text-muted); line-height: 1.5; }

@media (max-width: 768px) {
  .tool-grid { grid-template-columns: 1fr !important; }
  .result-grid { grid-template-columns: 1fr 1fr; }
  .related-tools-grid { grid-template-columns: 1fr; }
}
