/* STEP-19J-SYNC-CSS-SPLIT
   Sync page styles extracted from app.css to keep the global stylesheet smaller.
   Shared cards/forms/layout primitives remain in app.css. */

/* Step 18F — Sync settings and Cloudflare branch connection */
.sync-settings-card .sync-settings-form {
  margin-top: 14px;
}

.inline-checkbox {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  width: fit-content;
}

.inline-checkbox input {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}

.sync-toggle-field > span {
  margin-bottom: 6px;
}

.sync-settings-form input[readonly] {
  background: var(--surface-2);
  color: var(--text);
  font-weight: 800;
}

@media (max-width: 760px) {
  .sync-settings-card .settings-form-grid {
    grid-template-columns: 1fr;
  }
}

/* STEP-19D-DEFERRED-SYNC-UX */
.badge.success {
  background: #ecfdf3;
  color: #067647;
  border-color: #abefc6;
}

.badge.warn {
  background: #fffaeb;
  color: var(--warning);
  border-color: #fedf89;
}

.badge.danger {
  background: #fef3f2;
  color: var(--danger);
  border-color: #fecdca;
}

.sync-stage-card {
  display: grid;
  gap: 14px;
  border-inline-start: 5px solid var(--accent);
}

.sync-stage-deferred,
.sync-stage-branch_missing {
  border-inline-start-color: var(--line);
}

.sync-stage-partial,
.sync-stage-ready_offline {
  border-inline-start-color: #fdb022;
}

.sync-stage-connected,
.sync-stage-ready {
  border-inline-start-color: #12b76a;
}

.sync-stage-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.sync-stage-step {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 10px 12px;
  background: var(--surface-2);
  color: var(--muted);
  font-weight: 900;
  text-align: center;
}

.sync-stage-step.active {
  border-color: rgba(43, 120, 228, .28);
  background: rgba(239, 246, 255, .9);
  color: #174ea6;
}

.sync-warning-muted {
  border-color: rgba(43, 120, 228, .20);
  background: rgba(239, 246, 255, .65);
}

@media (max-width: 760px) {
  .sync-stage-steps {
    grid-template-columns: 1fr;
  }
}


/* STEP-19F-SYNC-BRANCH-VALIDATION */
.sync-settings-form input:disabled,
.sync-settings-form button:disabled {
  cursor: not-allowed;
}
.sync-stage-card .muted-text {
  margin-top: 8px;
  font-size: 0.9rem;
}

/* STEP-20AD-SYNC-LOCAL-READINESS */
.sync-local-readiness-card {
  display: grid;
  gap: 14px;
}

.sync-readiness-list {
  display: grid;
  gap: 10px;
}

.sync-readiness-item {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-2);
}

.sync-readiness-item.ok {
  border-color: rgba(18, 183, 106, .24);
  background: rgba(236, 253, 243, .65);
}

.sync-readiness-item.needed {
  border-color: rgba(253, 176, 34, .32);
  background: rgba(255, 250, 235, .78);
}

.sync-readiness-item.optional {
  border-color: rgba(43, 120, 228, .22);
  background: rgba(239, 246, 255, .62);
}

.sync-readiness-state {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--line);
  font-weight: 900;
  font-size: .82rem;
}

.sync-readiness-item strong,
.sync-readiness-item small,
.sync-readiness-item code {
  display: block;
}

.sync-readiness-item small {
  margin-top: 4px;
  color: var(--muted);
  line-height: 1.6;
}

.sync-readiness-item code {
  width: fit-content;
  max-width: 100%;
  margin-top: 6px;
  padding: 3px 7px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--line);
  direction: ltr;
  unicode-bidi: plaintext;
  font-size: .78rem;
  white-space: normal;
  word-break: break-word;
}

@media (max-width: 760px) {
  .sync-readiness-item {
    grid-template-columns: 1fr;
  }
  .sync-readiness-state {
    width: fit-content;
  }
}
