/* ===================================================================
   schedule_builder.css — styles for the reusable ScheduleBuilder widget.
   Uses the workflow.html dark-theme CSS variables with literal fallbacks
   so the component also renders correctly if dropped on another page.
   =================================================================== */

.sb {
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  color: var(--text, #fff);
}

.sb-row { display: flex; flex-direction: column; gap: 5px; }

.sb-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted, #a1a1aa);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

.sb-select,
.sb-input {
  width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text, #fff);
  background: var(--bg-input, #27272a);
  border: 1px solid var(--border, #3f3f46);
  border-radius: 6px;
  outline: none;
}

.sb-select:focus,
.sb-input:focus { border-color: var(--accent, #2563eb); }

.sb-input-time { width: 130px; }
.sb-input-num  { width: 90px; }

.sb-group { display: flex; flex-direction: column; gap: 8px; }

.sb-note {
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-muted, #a1a1aa);
}

.sb-inline {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* ── weekday selector ─────────────────────────────────────────── */
.sb-days {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.sb-day {
  min-width: 42px;
  padding: 7px 6px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  color: var(--text-muted, #a1a1aa);
  background: var(--bg-input, #27272a);
  border: 1px solid var(--border, #3f3f46);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}

.sb-day:hover { border-color: var(--border-light, #52525b); }

.sb-day-on {
  color: #fff;
  background: var(--accent, #2563eb);
  border-color: var(--accent, #2563eb);
}

/* ── advanced (raw cron) ──────────────────────────────────────── */
.sb-check {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  color: var(--text-muted, #a1a1aa);
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}

.sb-check input { cursor: pointer; margin: 0; }

.sb-adv { display: flex; flex-direction: column; gap: 5px; }

.sb-adv .sb-input { font-family: 'Fira Code', monospace; font-size: 12px; }

/* ── summary / preview panel ──────────────────────────────────── */
.sb-summary {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 10px 12px;
  background: var(--bg-card, #1e1e23);
  border: 1px solid var(--border, #3f3f46);
  border-radius: 6px;
}

.sb-summary-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--text, #fff);
}

.sb-next {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 11px;
}

.sb-next-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted, #a1a1aa);
}

.sb-next-item {
  padding: 2px 8px;
  background: var(--bg-input, #27272a);
  border: 1px solid var(--border, #3f3f46);
  border-radius: 4px;
  color: var(--text-muted, #a1a1aa);
  white-space: nowrap;
}

.sb-muted { color: var(--text-faint, #52525b); font-size: 11px; }

.sb-error {
  font-size: 12px;
  color: var(--error, #ef4444);
  line-height: 1.45;
}
.sb-error:empty { display: none; }

.sb-cron-hint {
  font-size: 11px;
  color: var(--text-muted, #a1a1aa);
}
.sb-cron-hint code {
  font-family: 'Fira Code', monospace;
  color: var(--text, #fff);
}

.sb-invalid .sb-summary { border-color: var(--error, #ef4444); }
