/* Transpose Tool Styles */
.tool-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: var(--space-lg); margin-bottom: var(--space-lg); }
.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; }
.panel-subtitle { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-secondary); margin: var(--space-md) 0 var(--space-sm); 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-xs) var(--space-sm); box-sizing: border-box; transition: border-color 0.2s; }
.input-field:focus { outline: none; border-color: var(--color-primary); }

/* Select dropdown */
.select-field { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2300ff41' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; }
.select-field option { background: var(--color-bg); color: var(--color-text); }

/* Chord text area */
.chord-textarea { font-family: var(--font-mono); font-size: var(--fs-base); line-height: 1.8; resize: vertical; min-height: 160px; background: var(--color-bg); color: var(--color-text); white-space: pre-wrap; }
.chord-textarea::placeholder { color: var(--color-text-muted); opacity: 0.6; }

/* Semitone controls */
.semitone-control { display: flex; align-items: center; gap: var(--space-sm); }
.semitone-btn { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-primary); font-size: 1.2rem; font-weight: 700; cursor: pointer; transition: all 0.2s; }
.semitone-btn:hover { border-color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 10%, transparent); }
.semitone-display { flex: 1; text-align: center; font-family: var(--font-mono); font-size: var(--fs-base); color: var(--color-secondary); }
.slider-wrap { margin-top: var(--space-xs); }
.slider { width: 100%; accent-color: var(--color-primary); cursor: pointer; }
.slider-labels { display: flex; justify-content: space-between; font-size: var(--fs-xs); color: var(--color-text-muted); font-family: var(--font-mono); margin-top: 2px; }

/* Quick transpose buttons */
.quick-transpose { margin-top: var(--space-md); }
.quick-btn-row { display: flex; gap: var(--space-xs); margin-top: var(--space-xs); }
.quick-btn { 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); font-weight: 600; cursor: pointer; text-align: center; transition: all 0.2s; }
.quick-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* Toggle checkboxes */
.toggle-row { margin-top: var(--space-md); display: flex; flex-direction: column; gap: var(--space-xs); }
.toggle-label { display: flex; align-items: center; gap: var(--space-xs); font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text-muted); cursor: pointer; }
.toggle-label input[type="checkbox"] { accent-color: var(--color-primary); width: 16px; height: 16px; cursor: pointer; }

/* Output placeholder */
.output-placeholder { text-align: center; padding: var(--space-xl) var(--space-md); color: var(--color-text-muted); font-family: var(--font-mono); font-size: var(--fs-sm); border: 1px dashed var(--color-border); border-radius: var(--radius-md); }

/* Side-by-side chord display */
.side-by-side { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.side-col { min-width: 0; }
.side-title { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.1em; margin: 0 0 var(--space-xs); }
.chord-display { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-md); font-family: var(--font-mono); font-size: var(--fs-sm); line-height: 1.8; color: var(--color-text); overflow-x: auto; white-space: pre-wrap; word-wrap: break-word; margin: 0; min-height: 80px; }

/* Chord chips */
.chord-chips { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.chord-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 20px; font-family: var(--font-mono); font-size: var(--fs-sm); transition: all 0.2s; }
.chord-chip__original { color: var(--color-text-muted); }
.chord-chip__arrow { color: var(--color-primary); font-size: 0.8em; }
.chord-chip__transposed { color: var(--color-secondary); font-weight: 600; }

/* Nashville number badges */
.nashville-display { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.nashville-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; padding: 6px 12px; background: color-mix(in srgb, var(--color-primary) 15%, transparent); border: 1px solid var(--color-primary); border-radius: var(--radius-md); font-family: var(--font-mono); font-size: var(--fs-base); color: var(--color-primary); font-weight: 600; }
.nashville-badge--minor { background: color-mix(in srgb, var(--color-secondary) 15%, transparent); border-color: var(--color-secondary); color: var(--color-secondary); }

/* Capo table */
.capo-panel { margin-top: var(--space-lg); }
.capo-subtitle { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text-muted); margin-bottom: var(--space-md); }
.capo-table { width: 100%; }
.table-wrap { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: var(--fs-sm); }
.data-table th { background: var(--color-surface); color: var(--color-primary); padding: var(--space-xs) var(--space-sm); text-align: left; border-bottom: 1px solid var(--color-border); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.05em; }
.data-table td { padding: var(--space-xs) var(--space-sm); border-bottom: 1px solid color-mix(in srgb, var(--color-border) 50%, transparent); color: var(--color-text); }
.data-table tr:hover td { background: color-mix(in srgb, var(--color-primary) 5%, transparent); }
.data-table tr.capo-easy td { color: var(--color-primary); font-weight: 600; }
.data-table tr.capo-open td { color: var(--color-secondary); }
.ease-badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: var(--fs-xs); font-weight: 600; }
.ease-badge--easy { background: color-mix(in srgb, var(--color-primary) 20%, transparent); color: var(--color-primary); }
.ease-badge--common { background: color-mix(in srgb, var(--color-secondary) 20%, transparent); color: var(--color-secondary); }
.ease-badge--hard { background: color-mix(in srgb, var(--color-text-muted) 15%, transparent); color: var(--color-text-muted); }

/* Shortcuts panel */
.shortcuts-panel { margin-bottom: var(--space-lg); }
.shortcut-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-sm); }
.shortcut-btn { display: flex; flex-direction: column; align-items: center; gap: var(--space-xs); padding: var(--space-md); background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); cursor: pointer; transition: all 0.2s; text-align: center; }
.shortcut-btn:hover { border-color: var(--color-primary); background: color-mix(in srgb, var(--color-primary) 5%, transparent); }
.shortcut-icon { font-size: 1.5rem; }
.shortcut-name { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text); font-weight: 600; }
.shortcut-detail { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--color-text-muted); }

/* Related tools */
.related-tools-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); max-width: 700px; margin: 0 auto; }
.related-tool-card { display: flex; flex-direction: column; align-items: center; gap: var(--space-sm); padding: var(--space-lg) var(--space-md); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); text-decoration: none; transition: all 0.2s; }
.related-tool-card:hover { border-color: var(--color-primary); transform: translateY(-2px); }
.related-tool-icon { font-size: 2rem; }
.related-tool-name { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-text); text-align: center; }

/* Highlighted chord in output */
.chord-highlight { color: var(--color-primary); font-weight: 600; }
.chord-highlight--new { color: var(--color-secondary); font-weight: 600; }

/* Content */
.content-section h2 { color: var(--color-primary); font-family: var(--font-display); margin-bottom: var(--space-md); }
.content-section h3 { color: var(--color-secondary); margin: var(--space-lg) 0 var(--space-sm); }
.formula-explainer { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); margin: var(--space-md) 0; }
.formula-explainer--4col { grid-template-columns: repeat(4, 1fr); }
.formula-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-md); }
.fc-title { font-size: var(--fs-sm); color: var(--color-primary); font-weight: 600; margin-bottom: var(--space-xs); }
.fc-formula { font-family: var(--font-mono); font-size: 1.1rem; color: var(--color-secondary); margin: var(--space-xs) 0; padding: var(--space-xs) var(--space-sm); background: var(--color-bg); border-radius: var(--radius-sm); }
.fc-desc { font-size: var(--fs-sm); color: var(--color-text-muted); line-height: 1.6; }

/* FAQ */
.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; }
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after { content: '+'; color: var(--color-primary); font-size: 1.2em; }
details[open] .faq-question::after { content: '\2212'; }
.faq-answer { padding: 0 var(--space-md) var(--space-md); color: var(--color-text-muted); line-height: 1.7; border-top: 1px solid var(--color-border); }

/* Responsive */
@media (max-width: 768px) {
  .tool-grid { grid-template-columns: 1fr !important; }
  .side-by-side { grid-template-columns: 1fr; }
  .formula-explainer { grid-template-columns: 1fr; }
  .formula-explainer--4col { grid-template-columns: 1fr 1fr; }
  .shortcut-grid { grid-template-columns: 1fr 1fr; }
  .related-tools-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .formula-explainer--4col { grid-template-columns: 1fr; }
  .shortcut-grid { grid-template-columns: 1fr; }
  .quick-btn-row { flex-wrap: wrap; }
  .quick-btn { flex: 1 1 40%; }
}
