*{box-sizing:border-box;margin:0;padding:0}body{color:#c9d1d9;background:#0d1117;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6}#root{max-width:1200px;margin:0 auto;padding:0 20px}.app{padding-bottom:60px}.app-header{text-align:center;border-bottom:1px solid #21262d;margin-bottom:40px;padding:40px 0 20px;position:relative}.back-link{color:#58a6ff;font-size:14px;text-decoration:none;position:absolute;top:20px;left:0}.back-link:hover{text-decoration:underline}.app-header h1{color:#f0f6fc;margin-bottom:8px;font-size:2.5rem}.subtitle{color:#8b949e;font-size:1.1rem}.educational-content{margin-bottom:40px}.edu-section{background:#161b22;border:1px solid #21262d;border-radius:12px;margin-bottom:20px;padding:28px}.edu-section h2{color:#f0f6fc;margin-bottom:12px;font-size:1.4rem}.edu-section p{margin-bottom:12px;line-height:1.7}.ratio-examples{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:20px;display:grid}.ratio-example{text-align:center;background:#0d1117;border:1px solid #21262d;border-radius:8px;padding:20px}.ratio-big{color:#4fc3f7;font-family:Consolas,monospace;font-size:2rem;font-weight:700}.ratio-label{color:#f0f6fc;margin:4px 0;font-weight:600}.ratio-desc{color:#8b949e;font-size:.85rem}.learn-more-btn{color:#58a6ff;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:6px;margin:20px auto 0;padding:8px 20px;font-size:.9rem;transition:all .2s;display:block}.learn-more-btn:hover{background:#58a6ff1a;border-color:#58a6ff}.consonance-definitions{flex-direction:column;gap:16px;margin-top:16px;display:flex}.consonance-def{background:#0d1117;border:1px solid #21262d;border-radius:8px;padding:20px}.consonance-def h3{color:#4fc3f7;margin-bottom:8px;font-size:1.1rem}.consonance-def p{color:#c9d1d9;margin-bottom:10px;line-height:1.6}.consonance-def ul{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:6px;margin:0;padding:0;list-style:none;display:grid}.consonance-def li{color:#c9d1d9;padding:4px 0;font-size:.95rem}.consonance-def li:before{content:"♪ ";color:#4fc3f7}.math-examples{margin-top:16px}.math-heading{color:#8b949e;margin-bottom:12px;font-size:.95rem}.math-example{background:#0d1117;border:1px solid #21262d;border-radius:8px;margin-bottom:8px;padding:12px 20px}.math-formula{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.math-interval{color:#4fc3f7;min-width:180px;font-weight:600}.math-calc{color:#c9d1d9;flex:1;font-family:Consolas,Monaco,monospace;font-size:.95rem}.math-calc strong{color:#66bb6a}.math-note{color:#8b949e;min-width:50px;font-size:.9rem}.waveform-definitions{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-top:16px;display:grid}.waveform-def{background:#0d1117;border:1px solid #21262d;border-radius:8px;padding:20px}.waveform-def h3{color:#4fc3f7;margin-bottom:8px;font-size:1.1rem}.waveform-def p{color:#c9d1d9;font-size:.95rem;line-height:1.6}.controls-section{background:#161b22;border:1px solid #21262d;border-radius:12px;margin-bottom:30px;padding:28px}.controls-section h2{color:#f0f6fc;margin-bottom:16px}.frequency-input-group{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.frequency-input-group label{color:#8b949e;align-items:center;gap:8px;font-size:.95rem;display:flex}.freq-input{color:#f0f6fc;background:#0d1117;border:1px solid #30363d;border-radius:6px;width:120px;padding:8px 12px;font-family:Consolas,monospace;font-size:1.1rem}.freq-input:focus{border-color:#4fc3f7;outline:none}.note-label{color:#4fc3f7;font-family:Consolas,monospace;font-size:1.2rem;font-weight:600}.frequency-slider{flex:1;min-width:200px}.frequency-slider input[type=range]{accent-color:#4fc3f7;width:100%}.presets{flex-wrap:wrap;gap:8px;width:100%;margin-top:8px;display:flex}.preset-btn{color:#c9d1d9;cursor:pointer;background:#21262d;border:1px solid #30363d;border-radius:6px;padding:6px 14px;font-size:.85rem;transition:all .2s}.preset-btn:hover{background:#30363d;border-color:#4fc3f7}.preset-btn.active{color:#4fc3f7;background:#4fc3f726;border-color:#4fc3f7}.waveform-picker{align-items:center;gap:8px;width:100%;margin-top:8px;display:flex}.waveform-label{color:#8b949e;white-space:nowrap;margin-right:4px;font-size:.9rem}.waveform-btn{color:#c9d1d9;cursor:pointer;background:#21262d;border:1px solid #30363d;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:.85rem;transition:all .2s;display:flex}.waveform-btn:hover{background:#30363d;border-color:#4fc3f7}.waveform-btn.active{color:#4fc3f7;background:#4fc3f726;border-color:#4fc3f7}.section{margin-bottom:30px}.section h2{color:#f0f6fc;margin-bottom:8px;font-size:1.4rem}.section-desc{color:#8b949e;margin-bottom:16px;font-size:.95rem}.interval-table-container{border:1px solid #21262d;border-radius:8px;overflow-x:auto}.interval-table{border-collapse:collapse;width:100%;font-size:.9rem}.interval-table th{color:#8b949e;text-align:left;text-transform:uppercase;letter-spacing:.5px;background:#161b22;border-bottom:1px solid #21262d;padding:10px 12px;font-size:.8rem;font-weight:600}.interval-table td{border-bottom:1px solid #161b22;padding:8px 12px}.interval-table tr{background:#0d1117;transition:background .15s}.interval-table tr:hover{background:#161b22}.interval-table tr.selected{background:#4fc3f714}.checkbox-cell{cursor:pointer;align-items:center;gap:6px;display:flex}.color-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.interval-name{flex-direction:column;display:flex}.interval-name strong{color:#f0f6fc}.full-name{color:#8b949e;font-size:.78rem}.ratio-cell{color:#4fc3f7;font-family:Consolas,monospace;font-weight:600}.decimal-cell{color:#8b949e;font-family:Consolas,monospace}.freq-cell{color:#f0f6fc;font-family:Consolas,monospace}.note-cell{color:#ffa726;font-family:Consolas,monospace}.consonance-badge{color:#0d1117;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.volume-cell{min-width:80px}.volume-slider-row{align-items:center;gap:4px;display:flex}.volume-slider{accent-color:#4fc3f7;cursor:pointer;width:55px}.volume-pct{color:#8b949e;min-width:28px;font-family:Consolas,monospace;font-size:.7rem}.play-cell{gap:4px;display:flex}.play-btn{color:#0d1117;cursor:pointer;background:#4fc3f7;border:none;border-radius:6px;padding:6px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.play-btn:hover{background:#81d4fa;transform:translateY(-1px)}.play-btn.small{padding:4px 8px;font-size:.8rem}.play-btn.playing{color:#fff;background:#ef5350}.play-btn.outline{color:#4fc3f7;background:0 0;border:1px solid #4fc3f7}.play-btn.outline:hover{background:#4fc3f71a}.visualization-section{background:#161b22;border:1px solid #21262d;border-radius:12px;padding:28px}.viz-controls{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;display:flex}.selected-info{flex:1;min-width:200px}.selected-tag{color:#4fc3f7;background:#21262d;border-radius:12px;margin:2px 4px;padding:2px 10px;font-family:Consolas,monospace;font-size:.82rem;display:inline-block}.consonance-meter{align-items:center;gap:8px;font-size:.9rem;display:flex}.consonance-label{min-width:130px;font-weight:700}.consonance-bar{background:#21262d;border-radius:4px;width:100px;height:8px;overflow:hidden}.consonance-fill{border-radius:4px;height:100%;transition:all .3s}.play-controls{align-items:center;gap:8px;display:flex}.toggle-label{color:#8b949e;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;margin-left:4px;font-size:.85rem;display:flex}.toggle-label:hover{color:#c9d1d9}.toggle-label input[type=checkbox]{accent-color:#4fc3f7;cursor:pointer}.cycles-control{align-items:center;width:100%;display:flex}.cycles-control label{color:#8b949e;align-items:center;gap:10px;width:100%;font-size:.85rem;display:flex}.cycles-control strong{color:#4fc3f7;text-align:center;min-width:28px}.cycles-slider{accent-color:#4fc3f7;cursor:pointer;flex:1}.info-tooltip{align-items:center;margin-left:2px;display:inline-flex;position:relative}.info-icon{color:#8b949e;cursor:help;background:#30363d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:.7rem;font-weight:700;display:inline-flex}.info-popup{color:#c9d1d9;z-index:10;pointer-events:none;background:#1c2130;border:1px solid #30363d;border-radius:8px;width:280px;padding:12px 14px;font-size:.82rem;font-weight:400;line-height:1.5;display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.info-tooltip:hover .info-popup,.info-tooltip:focus-within .info-popup{display:block}.viz-hint{color:#8b949e;margin-bottom:12px;font-size:.85rem}.chord-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.chord-card{background:#161b22;border:1px solid #21262d;border-radius:10px;padding:20px;transition:border-color .2s}.chord-card:hover{border-color:#30363d}.chord-card h4{color:#f0f6fc;margin-bottom:6px;font-size:1.05rem}.chord-description{color:#8b949e;margin-bottom:12px;font-size:.85rem}.chord-notes{flex-wrap:wrap;gap:8px;margin-bottom:8px;display:flex}.chord-note{color:#f0f6fc;background:#0d1117;border-radius:6px;flex-direction:column;align-items:center;padding:6px 12px;font-family:Consolas,monospace;font-weight:600;display:flex}.chord-note.clickable{cursor:pointer;border:1px solid #0000;transition:all .15s}.chord-note.clickable:hover{background:#21262d;border-color:#4fc3f7}.chord-note.clickable.active{color:#4fc3f7;background:#4fc3f733;border-color:#4fc3f7}.chord-note small{color:#8b949e;font-size:.72rem;font-weight:400}.chord-ratios{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.ratio-tag{color:#4fc3f7;background:#4fc3f71a;border-radius:4px;padding:2px 8px;font-family:Consolas,monospace;font-size:.78rem}.chord-actions{gap:8px;display:flex}.app-footer{text-align:center;color:#8b949e;border-top:1px solid #21262d;margin-top:40px;padding:20px;font-size:.85rem}@media (width<=768px){.app-header h1{font-size:1.8rem}.frequency-input-group{flex-direction:column;align-items:stretch}.waveform-picker{flex-wrap:wrap}.chord-grid{grid-template-columns:1fr}.interval-table{font-size:.8rem}.interval-table th,.interval-table td{padding:6px 8px}.interval-table th:nth-child(4),.interval-table td:nth-child(4),.interval-table th:nth-child(7),.interval-table td:nth-child(7){display:none}.viz-controls{flex-direction:column;align-items:stretch}.consonance-meter,.play-controls{flex-wrap:wrap}}@media (width<=480px){#root{padding:0 12px}.app-header{padding:30px 0 16px}.app-header h1{font-size:1.5rem}.subtitle{font-size:.9rem}.back-link{margin-bottom:12px;display:block;position:static}.edu-section{padding:20px 16px}.ratio-examples{grid-template-columns:repeat(2,1fr);gap:10px}.ratio-big{font-size:1.5rem}.ratio-example{padding:14px 10px}.controls-section{padding:20px 16px}.presets{gap:6px}.preset-btn{padding:5px 10px;font-size:.78rem}.waveform-picker{flex-wrap:wrap}.waveform-btn{padding:5px 10px;font-size:.78rem}.interval-table{font-size:.75rem}.interval-table th,.interval-table td{padding:6px}.interval-table th:nth-child(4),.interval-table td:nth-child(4),.interval-table th:nth-child(6),.interval-table td:nth-child(6),.interval-table th:nth-child(7),.interval-table td:nth-child(7){display:none}.play-btn.small{padding:4px 6px;font-size:.72rem}.play-cell{gap:3px}.visualization-section{padding:20px 12px}.selected-tag{padding:2px 8px;font-size:.75rem}.play-controls{flex-wrap:wrap;gap:6px}.play-btn{padding:6px 12px;font-size:.82rem}.toggle-label{font-size:.78rem}.chord-card{padding:16px}.chord-note{padding:5px 8px;font-size:.85rem}.chord-note small{font-size:.65rem}.app-footer{padding:16px 8px;font-size:.78rem}}
