/* ── Shared SRS Dashboard Styles ── */
.srs-dash-wrap {
  width: 100%;
  max-width: 760px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.srs-dash-title {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 600;
  margin-bottom: 4px;
}

.srs-dash-title span {
  color: var(--accent);
}

/* Reusing srs-index-card style from index.html or creating a shared one */
.srs-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 28px 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.srs-card-title {
  font-family: var(--font-mono);
  font-size: .7rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
}

.srs-due-display {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.srs-due-num {
  font-family: var(--font-serif);
  font-size: 3.5rem;
  font-weight: 600;
  line-height: 1;
  color: var(--accent);
}

.srs-due-num.zero {
  color: var(--text-3);
}

.srs-due-label {
  font-size: 1rem;
  color: var(--text-2);
}

.srs-stats-row {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.srs-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.srs-stat-num {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text);
}

.srs-stat-label {
  font-size: .72rem;
  color: var(--text-3);
}

.srs-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Filter button & Inline Panel */
.srs-btn-filter {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  background: var(--surface-2, #f0ede6) !important;
  color: var(--text-2) !important;
  border-color: var(--border) !important;
  padding: 10px 14px !important;
  font-family: var(--font-sans) !important;
  font-size: .88rem !important;
  position: relative !important;
}

.srs-btn-filter:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: var(--accent-light) !important;
}

.srs-btn-filter.active {
  background: var(--accent-light) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

.srs-filter-badge {
  background: var(--accent);
  color: #fff;
  font-size: .7rem;
  font-family: var(--font-sans);
  font-weight: 600;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.srs-filter-badge.hidden {
  display: none;
}

.srs-filter-chevron {
  font-size: .65rem;
  transition: transform .2s ease;
  opacity: .5;
  margin-left: auto;
}

.srs-filter-inline-panel {
  display: none;
  flex-direction: column;
  gap: 6px;
  padding: 0 4px 6px;
}

.srs-filter-inline-panel.open {
  display: flex;
}

.srs-filter-inline-divider {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 0;
}

.srs-filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.srs-filter-group-title {
  font-size: .68rem;
  font-family: var(--font-sans);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  margin-bottom: 4px;
}

.srs-filter-help {
  font-size: .7rem;
  color: var(--text-3);
  margin-bottom: 4px;
}

.srs-filter-checkbox-row {
  font-size: .88rem;
  color: var(--text-2);
}

.srs-filter-pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.srs-filter-stats {
  font-size: .8rem;
  color: var(--text-2);
  font-family: var(--font-sans);
  padding: 4px;
  margin-top: 2px;
}

.srs-filter-stats span {
  color: var(--text);
  font-weight: 700;
}

.srs-bootstrap-info {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .78rem;
  color: var(--text-3);
  font-family: var(--font-mono);
  margin-top: 12px;
}

.srs-bootstrap-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

.srs-topic-filter-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--accent-light);
  border: 1px solid var(--accent);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .85rem;
  color: var(--accent);
  margin-top: 4px;
}

.srs-topic-filter-icon {
  font-size: 1rem;
}

.srs-topic-filter-dismiss {
  margin-left: auto;
  background: none;
  border: none;
  color: var(--accent);
  font-weight: 600;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background .2s;
}

.srs-topic-filter-dismiss:hover {
  background: rgba(var(--accent-rgb), 0.1);
}

/* Breakdown: #srsQuizBreakdown — titles on page bg; bordered panel is table-only */
.srs-breakdown-root {
  margin-top: 24px;
}

.srs-breakdown-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  overflow: hidden;
  box-sizing: border-box;
}

.srs-breakdown-section {
  margin-top: 28px;
}

.srs-breakdown-section:first-child {
  margin-top: 0;
}

.srs-breakdown-section-title {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-2);
  line-height: 1.45;
  margin: 0 0 8px;
  padding: 0;
}

.srs-topic-row {
  cursor: pointer;
  transition: background .2s ease;
}

.srs-topic-row:hover {
  background: var(--surface-2);
}

.srs-topic-row.selected {
  background: var(--accent-light);
}

.srs-due-pill {
  background: var(--wrong-ring);
  color: white;
  font-size: .65rem;
  font-family: var(--font-mono);
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 99px;
  display: inline-block;
}

/* Index buttons matching SRS dashboard look */
.srs-idx-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 8px;
  font-family: var(--font-sans);
  font-size: .9rem;
  font-weight: 500;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: all var(--transition);
  text-decoration: none;
  background: none;
}

.srs-idx-btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.srs-idx-btn-primary:hover {
  filter: brightness(1.08);
}

.srs-idx-btn-primary.disabled {
  opacity: .45;
  cursor: not-allowed;
  filter: none;
}

.srs-idx-btn-ahead {
  background: var(--surface-2);
  color: var(--text-2);
  border-color: var(--border);
}

.srs-idx-btn-ahead:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-light);
}

/* iOS-style Switch Toggles */
.mode-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 10px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: .84rem;
  color: var(--text-2);
  transition: all 200ms ease;
  width: 100%;
  text-align: left;
}

.mode-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-light);
}

.mode-btn.active {
  border-color: var(--accent);
  background: var(--accent-light);
  color: var(--accent);
}

.mode-btn-switch {
  width: 32px;
  height: 18px;
  border-radius: 9px;
  background: var(--border);
  position: relative;
  transition: background 200ms ease;
  flex-shrink: 0;
}

.mode-btn.active .mode-btn-switch {
  background: var(--accent);
}

.mode-btn-switch::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  top: 2px;
  left: 2px;
  transition: transform 200ms ease;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .2);
}

.mode-btn.active .mode-btn-switch::after {
  transform: translateX(14px);
}

/* Accuracy Pills */
.srs-accuracy-pill {
  font-family: var(--font-sans);
  font-size: .75rem;
  font-weight: 500;
  padding: 6px 14px;
  border-radius: 99px;
  border: 1.5px solid var(--border);
  background: var(--surface);
  color: var(--text-2);
  cursor: pointer;
  transition: all 200ms ease;
}

.srs-accuracy-pill:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-light);
}

.srs-accuracy-pill.selected {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Minimum attempts slider (0-10 dragger for "filter for more than n") */
.srs-filter-slider-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 2px;
}

.srs-min-attempts-slider {
  -webkit-appearance: none;
  appearance: none;
  flex: 1;
  height: 6px;
  border-radius: 3px;
  cursor: pointer;
  outline: none;
  /* --slider-fill is set dynamically by JS (0%–100%) */
  background: linear-gradient(
    to right,
    var(--accent) var(--slider-fill, 0%),
    var(--border) var(--slider-fill, 0%)
  );
  transition: background 0.05s linear;
}

.srs-min-attempts-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  height: 18px;
  width: 18px;
  background: var(--accent);
  border-radius: 50%;
  cursor: pointer;
  border: 2.5px solid white;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18), 0 0 0 3px rgba(37, 99, 168, 0.12);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.srs-min-attempts-slider:hover::-webkit-slider-thumb {
  transform: scale(1.18);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.22), 0 0 0 5px rgba(37, 99, 168, 0.16);
}

.srs-min-attempts-slider:active::-webkit-slider-thumb {
  transform: scale(1.07);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15), 0 0 0 6px rgba(37, 99, 168, 0.2);
}

/* Firefox track */
.srs-min-attempts-slider::-moz-range-track {
  height: 6px;
  border-radius: 3px;
  background: var(--border);
}

/* Firefox filled portion */
.srs-min-attempts-slider::-moz-range-progress {
  height: 6px;
  border-radius: 3px;
  background: var(--accent);
}

.srs-min-attempts-slider::-moz-range-thumb {
  height: 18px;
  width: 18px;
  background: var(--accent);
  border-radius: 50%;
  cursor: pointer;
  border: 2.5px solid white;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18), 0 0 0 3px rgba(37, 99, 168, 0.12);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.srs-slider-value {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.78rem;
  min-width: 3.8em;
  text-align: center;
  padding: 3px 9px;
  border-radius: 20px;
  background: var(--surface-2);
  color: var(--text-2);
  letter-spacing: 0.01em;
  transition: background 0.2s ease, color 0.2s ease;
  white-space: nowrap;
}

.srs-slider-value.active {
  background: var(--accent-light);
  color: var(--accent);
}

.srs-attempts-group {
  margin-top: 6px;
  font-family: var(--font-sans);
}

.srs-attempts-group .srs-filter-group-title {
  margin-bottom: 8px;
}
