/* ── Settings ── */
.settings-section {
  margin-bottom: 18px;
}
.settings-section-primary {
  margin-top: 2px;
}
.settings-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin: 0 2px 9px;
}
.settings-section-head .section-label {
  margin: 0 0 4px;
}
.settings-card,
.settings-group {
  background: var(--material-raised);
  border: 1px solid var(--separator-soft);
  box-shadow: var(--shadow-card);
  border-radius: var(--radius);
  overflow: hidden;
}
.settings-section-primary .settings-card {
  background: var(--material-raised);
  border-color: color-mix(in srgb, var(--accent) 20%, var(--separator));
}
.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  font-size: 14px;
  color: var(--text);
  border-bottom: 1px solid var(--separator-soft);
  gap: 12px;
}
.settings-row:last-child { border-bottom: none; }
.settings-row span, .settings-row > div > div:first-child { color: var(--text); }
.settings-row-stack {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}
.settings-row-stack .accent-picker {
  justify-content: flex-start;
}
.prominent-row {
  min-height: 74px;
}
.danger-row {
  background: linear-gradient(90deg, transparent, var(--danger-light));
}
.settings-hint {
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.35;
  color: var(--text3);
}
.settings-row--stacked {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}
.settings-push-note {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.45;
  color: var(--text2);
}
.settings-push-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, transparent);
  background: color-mix(in srgb, var(--accent-light) 64%, var(--material-raised));
  color: var(--accent);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  transition: opacity var(--tr), transform var(--tr);
}
.settings-push-btn:active:not(:disabled):not(.is-disabled) {
  transform: scale(0.98);
  opacity: 0.92;
}
.settings-push-btn:disabled,
.settings-push-btn.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
  border-style: dashed;
}
.settings-select,
.settings-number,
.settings-text {
  flex: 0 0 auto;
  min-width: 104px;
  min-height: 36px;
  padding: 0 10px;
  border-radius: 12px;
  background: var(--material-field);
  border: 1px solid var(--separator);
  color: var(--text);
  font-size: 13px;
  text-align: right;
}
.settings-number {
  width: 68px;
}
.settings-text {
  width: min(42vw, 178px);
  font-weight: 700;
}
.settings-version {
  text-align: center;
  font-size: 11px;
  color: var(--text3);
  margin-top: 20px;
  letter-spacing: .04em;
}

/* Mode pill → 统一为 setting-action */
.setting-action {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 0;
  background: none;
  border: none;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity var(--tr);
}
.setting-action:active { opacity: .6; }
.setting-action.danger { color: var(--danger); }
.primary-action {
  min-height: 34px;
  padding: 0 13px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-weight: 760;
}
body:not(.light) .icon-sun  { display: none !important; }
body:not(.light) .icon-moon { display: block !important; }
body.light       .icon-moon { display: none !important; }
body.light       .icon-sun  { display: block !important; }

/* Accent picker */
.accent-picker { display: flex; gap: 9px; flex-wrap: wrap; }
.accent-swatch { width: 26px; height: 26px; border-radius: 50%; border: 2px solid transparent; transition: transform var(--tr), border-color var(--tr); }
.accent-swatch:active { transform: scale(.85); }
.accent-swatch.active { border-color: var(--text); transform: scale(1.1); }


/* ── 作息设置 ── */
.sched-summary {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 12px 14px; gap: 10px;
}
.settings-card .sched-summary {
  border: none;
  border-radius: 0;
  background: transparent;
}
.sched-summary-text { font-size: 13px; color: var(--text2); flex: 1; line-height: 1.5; }
.sched-input-wrap { display: flex; flex-direction: column; gap: 8px; }
.sched-templates { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.sched-tpl-label { font-size: 11px; color: var(--text3); }
.sched-tpl { font-size: 11px; font-weight: 600; padding: 4px 10px; border-radius: 99px; background: var(--bg3); color: var(--text2); border: 1px solid var(--border); transition: background var(--tr), color var(--tr); }
.sched-tpl:active { background: var(--accent-light); color: var(--accent); border-color: var(--accent); }

/* ── Toggle Switch ── */
.toggle { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; inset: 0; background: var(--bg4); border-radius: 99px; cursor: pointer; transition: background var(--tr); }
.toggle-slider::before { content: ''; position: absolute; left: 3px; top: 3px; width: 18px; height: 18px; border-radius: 50%; background: #fff; transition: transform var(--tr); box-shadow: 0 1px 4px rgba(0,0,0,.3); }
.toggle input:checked + .toggle-slider { background: var(--accent); }
.toggle input:checked + .toggle-slider::before { transform: translateX(18px); }

.task-item.pressing {
  transform: scale(.97);
  box-shadow: 0 0 0 2px var(--accent);
  transition: transform .48s ease, box-shadow .48s ease;
}
