/* Solfeggio Frequency Generator — local overrides (Card 16) */

.sfg-band-tag {
  display:inline-block;
  font-family:var(--font-mono);
  font-size:.5em;
  letter-spacing:.08em;
  color:#c026d3;
  background:rgba(192,38,211,.12);
  border:1px solid rgba(192,38,211,.45);
  padding:2px 8px;
  border-radius:4px;
  vertical-align:middle;
  margin-left:8px;
}

.sfg-warning {
  max-width:760px;
  margin:var(--space-md) auto 0;
  padding:var(--space-sm) var(--space-md);
  border:1px solid rgba(245,158,11,.4);
  background:rgba(245,158,11,.07);
  border-radius:var(--radius-sm);
  color:#fbbf24;
  font-size:.92rem;
  text-align:left;
  line-height:1.55;
}
.sfg-warning strong { color:#fde68a; }

/* Mode buttons */
.sfg-mode-row {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
}
.sfg-mode-btn {
  background:rgba(0,255,65,.04);
  border:1px solid rgba(0,255,65,.25);
  color:var(--color-text);
  font-family:var(--font-body);
  font-size:.92rem;
  font-weight:600;
  padding:10px 8px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  text-align:center;
  line-height:1.25;
  transition:background .15s,border-color .15s,color .15s;
}
.sfg-mode-btn__sub {
  display:block;
  font-family:var(--font-mono);
  font-size:.72rem;
  font-weight:400;
  color:var(--color-text-dim);
  margin-top:2px;
}
.sfg-mode-btn:hover {
  background:rgba(0,255,65,.08);
  border-color:rgba(0,255,65,.5);
}
.sfg-mode-btn[aria-checked="true"] {
  background:rgba(0,255,65,.18);
  border-color:var(--color-primary);
  color:var(--color-primary);
}
.sfg-mode-btn[aria-checked="true"] .sfg-mode-btn__sub { color:var(--color-primary); }

/* 9 frequency buttons - grid */
.sfg-freqs {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.sfg-freq-btn {
  --c:#00ff41;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:2px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.12);
  border-left:4px solid var(--c);
  color:var(--color-text);
  font-family:var(--font-body);
  font-weight:600;
  padding:8px 10px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  text-align:left;
  transition:background .15s,border-color .15s,transform .1s;
}
.sfg-freq-btn:hover {
  background:rgba(255,255,255,.06);
  transform:translateY(-1px);
}
.sfg-freq-btn[aria-checked="true"] {
  background:color-mix(in srgb,var(--c) 22%,transparent);
  border-color:var(--c);
  border-left-width:4px;
  color:#fff;
}
.sfg-freq-btn[disabled] {
  opacity:.5;
  cursor:not-allowed;
  transform:none;
}
.sfg-freq-btn__hz {
  font-family:var(--font-mono);
  font-size:1rem;
  color:var(--c);
}
.sfg-freq-btn__name {
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.06em;
  color:var(--color-text-dim);
  text-transform:uppercase;
}
.sfg-freq-btn[aria-checked="true"] .sfg-freq-btn__name { color:#fff; }

/* Ambient buttons */
.sfg-ambient-row {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;
}
.sfg-ambient-btn {
  background:rgba(0,255,65,.04);
  border:1px solid rgba(0,255,65,.2);
  color:var(--color-text);
  font-family:var(--font-mono);
  font-size:.78rem;
  padding:7px 4px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.sfg-ambient-btn[aria-checked="true"] {
  background:rgba(0,255,65,.18);
  border-color:var(--color-primary);
  color:var(--color-primary);
}

/* Timer buttons */
.sfg-timer-btns {
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:6px;
  margin-bottom:var(--space-md);
}
.sfg-timer-btn {
  background:rgba(0,255,65,.05);
  border:1px solid rgba(0,255,65,.25);
  color:var(--color-text);
  font-family:var(--font-mono);
  font-size:.78rem;
  padding:8px 4px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:600;
}
.sfg-timer-btn:hover { background:rgba(0,255,65,.1); }
.sfg-timer-btn.is-active {
  background:rgba(0,255,65,.22);
  border-color:var(--color-primary);
  color:var(--color-primary);
}
.sfg-timer-info {
  background:rgba(0,255,65,.04);
  border:1px solid rgba(0,255,65,.18);
  border-radius:var(--radius-sm);
  padding:var(--space-sm);
}
.sfg-timer-info__label {
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.06em;
  color:var(--color-text-dim);
  text-transform:uppercase;
  text-align:center;
}
.sfg-timer-info__value {
  font-family:var(--font-mono);
  font-size:1.6rem;
  font-weight:700;
  color:var(--color-primary);
  text-align:center;
  margin:4px 0;
}
.sfg-timer-info__hint {
  font-size:.78rem;
  color:var(--color-text-dim);
  text-align:center;
  line-height:1.45;
}

/* Bell buttons */
.sfg-bell-row {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
}
.sfg-bell-btn {
  background:rgba(0,255,65,.04);
  border:1px solid rgba(0,255,65,.2);
  color:var(--color-text);
  font-family:var(--font-mono);
  font-size:.78rem;
  padding:8px 4px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.sfg-bell-btn[aria-checked="true"] {
  background:rgba(0,255,65,.18);
  border-color:var(--color-primary);
  color:var(--color-primary);
}

/* Export */
.sfg-export-row {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
}
.sfg-export-btn {
  background:rgba(192,38,211,.07);
  border:1px solid rgba(192,38,211,.35);
  color:#e879f9;
  font-family:var(--font-mono);
  font-size:.86rem;
  padding:8px 4px;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:600;
}
.sfg-export-btn:hover {
  background:rgba(192,38,211,.18);
  border-color:#c026d3;
}

/* Status */
.sfg-status {
  margin-top:var(--space-sm);
  text-align:center;
  font-family:var(--font-mono);
  font-size:.85rem;
  color:var(--color-text-dim);
  min-height:1.5em;
}
.sfg-status.is-playing { color:var(--color-primary); }
.sfg-status.is-fading  { color:#fbbf24; }
.sfg-status.is-error   { color:#ef4444; }

/* Live readout cells */
.sfg-cells {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
}
.sfg-cell {
  background:rgba(255,255,255,.03);
  border:1px solid rgba(0,255,65,.15);
  border-radius:var(--radius-sm);
  padding:10px;
  text-align:center;
}
.sfg-cell--active {
  border-color:rgba(192,38,211,.5);
  background:rgba(192,38,211,.06);
}
.sfg-cell__label {
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.06em;
  color:var(--color-text-dim);
  text-transform:uppercase;
}
.sfg-cell__value {
  font-family:var(--font-mono);
  font-size:1.15rem;
  font-weight:700;
  color:var(--color-primary);
  margin-top:4px;
  word-break:break-word;
}
.sfg-cell--active .sfg-cell__value { color:#e879f9; }
.sfg-cell__sub {
  font-size:.75rem;
  color:var(--color-text-dim);
  margin-top:2px;
  word-break:break-word;
}

/* Timeline visualization */
.sfg-timeline-viz { background:#020308; }

@media (max-width:960px) {
  .sfg-freqs { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px) {
  .sfg-freqs { grid-template-columns:1fr 1fr; }
  .sfg-timer-btns { grid-template-columns:repeat(3,1fr); }
  .sfg-ambient-row { grid-template-columns:repeat(2,1fr); }
}
