/* Phase 1 placeholder. Tailwind takes over in Phase 2. */
:root { font-family: system-ui, sans-serif; line-height: 1.5; color: #1a1a1a; }
body { margin: 0; background: #fafafa; }
.topbar {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.75rem 1.25rem; background: #fff; border-bottom: 1px solid #e5e5e5;
}
.topbar .brand { font-weight: 600; text-decoration: none; color: inherit; }
.topbar .nav { display: flex; gap: 1rem; }
.topbar .nav a { color: #444; text-decoration: none; }
.topbar .nav a:hover { color: #000; }
.topbar .user { margin-left: auto; color: #555; font-size: 0.9rem; text-decoration: none; }
.topbar .user:hover { color: #000; text-decoration: underline; }
.account-info { display: grid; grid-template-columns: 8rem 1fr; gap: 0.4rem 1rem; margin: 1rem 0 1.5rem; }
.account-info dt { color: #666; }
.account-info dd { margin: 0; }
section + section { margin-top: 2rem; }
.post-body { background: #fafafa; border-left: 3px solid #ccc; padding: 0.75rem 1rem; margin: 0.5rem 0 1.5rem; white-space: pre-wrap; }
.range-form { display: flex; gap: 1rem; align-items: end; margin: 1rem 0; }
.range-form label { display: flex; flex-direction: column; gap: 0.25rem; font-size: 0.85rem; color: #555; }
.range-form input[type=date] { padding: 0.4rem; border: 1px solid #ccc; border-radius: 4px; }
table tr.totals { background: #fafafa; border-top: 2px solid #ddd; }
table tr.totals th { font-weight: 600; }
.error-details { display: inline-block; margin-left: 0.5rem; }
.error-details > summary { cursor: pointer; color: #b00020; font-size: 0.85rem; }
.error-details > pre { white-space: pre-wrap; word-break: break-word; background: #fdeaea; padding: 0.5rem; border-radius: 4px; font-size: 0.8rem; max-width: 32rem; margin: 0.5rem 0 0; }
.target-row { display: flex; flex-direction: column; gap: 0.25rem; padding: 0.4rem 0; border-bottom: 1px solid #f0f0f0; }
.target-row:last-of-type { border-bottom: 0; }
.target-override { width: 100%; padding: 0.3rem 0.4rem; border: 1px solid #d8d8d8; border-radius: 3px; font-size: 0.85rem; resize: vertical; }
.target-badges { display: flex; flex-wrap: wrap; gap: 0.25rem; }
.target-detail { background: #fafafa; border: 1px solid #e8e8e8; border-radius: 6px; padding: 0.75rem 1rem; margin: 0.75rem 0; }
.target-detail h3 { display: flex; gap: 0.5rem; align-items: center; margin: 0 0 0.5rem; font-size: 1rem; }
.target-meta { display: grid; grid-template-columns: 8rem 1fr; gap: 0.2rem 1rem; margin: 0.4rem 0; font-size: 0.9rem; }
.target-meta dt { color: #666; }
.target-meta dd { margin: 0; }
.target-actions { display: flex; gap: 0.75rem; align-items: center; margin-top: 0.5rem; }
.datetime-pair { display: flex; gap: 1rem; align-items: end; flex-wrap: wrap; }
.datetime-pair label { flex: 1; min-width: 8rem; }
.datetime-pair input { width: 100%; }
.clock-picker { display: inline-flex; flex-direction: column; align-items: center; gap: 0.5rem; padding: 0.75rem; border: 1px solid #e5e5e5; border-radius: 8px; background: #fafafa; user-select: none; }
.clock-picker .cp-display { font-size: 1.5rem; font-weight: 600; font-variant-numeric: tabular-nums; color: #111; }
.clock-picker svg { display: block; cursor: pointer; }
.clock-picker .cp-face-bg { fill: #fff; stroke: #d8d8d8; stroke-width: 1; }
.clock-picker .cp-num { font-size: 14px; fill: #333; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; pointer-events: none; }
.clock-picker .cp-hand { stroke: #1a1a1a; stroke-width: 3; stroke-linecap: round; }
.clock-picker .cp-center { fill: #1a1a1a; }
.clock-picker .cp-controls { display: flex; gap: 0.5rem; align-items: center; }
.clock-picker .cp-mode { font-size: 0.8rem; color: #666; padding: 0.25rem 0.5rem; border-radius: 3px; background: #fff; border: 1px solid #e5e5e5; }
.clock-picker .cp-ampm { font-size: 0.85rem; padding: 0.25rem 0.7rem; border: 1px solid #ccc; background: #fff; border-radius: 3px; cursor: pointer; font-weight: 600; }
.clock-picker .cp-ampm:hover { background: #f0f0f0; }
.topbar .inline { display: inline; margin: 0; }
main { max-width: 56rem; margin: 2rem auto; padding: 0 1.25rem; }
fieldset { border: 1px solid #ddd; border-radius: 4px; padding: 0.5rem 1rem; margin: 0.75rem 0; }
fieldset legend { padding: 0 0.5rem; color: #444; }
.checkbox { display: flex; align-items: center; gap: 0.5rem; margin: 0.25rem 0; }
.checkbox input { width: auto; }
.muted { color: #888; font-size: 0.85em; }
.hint { color: #666; font-size: 0.9rem; }
.button { display: inline-block; padding: 0.4rem 0.8rem; background: #1a1a1a; color: #fff; text-decoration: none; border-radius: 4px; }
.link-button { background: none; border: 0; color: #b00020; cursor: pointer; padding: 0; font: inherit; }
table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
table th, table td { text-align: left; padding: 0.5rem; border-bottom: 1px solid #eee; }
table .body { max-width: 24rem; overflow: hidden; text-overflow: ellipsis; }
.state { display: inline-block; padding: 0.1rem 0.5rem; border-radius: 3px; font-size: 0.85em; }
.state-pending { background: #fff7d6; color: #6b4f00; }
.state-claimed, .state-posting { background: #d6eaff; color: #0a3d7a; }
.state-posted  { background: #e7f4ec; color: #114a2b; }
.state-failed  { background: #fdeaea; color: #b00020; }
.platform-grid { display: grid; gap: 0.75rem; grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr)); margin: 1rem 0; }
.platform-card { background: #fff; border: 1px solid #e5e5e5; border-radius: 6px; padding: 0.75rem 1rem; }
.platform-card h3 { margin: 0 0 0.5rem; text-transform: capitalize; }
.platform-card form { display: flex; flex-direction: column; gap: 0.5rem; }
.platform-card input[type=text] { padding: 0.4rem; border: 1px solid #ccc; border-radius: 4px; }
.platform-card button { padding: 0.4rem 0.6rem; background: #1a1a1a; color: #fff; border: 0; border-radius: 4px; cursor: pointer; }
a.platform-card { color: inherit; text-decoration: none; }
a.platform-card:hover { border-color: #888; }
.platform-card .muted { margin: 0; font-size: 0.85rem; }
.wizard { padding-left: 0; counter-reset: step; list-style: none; }
.wizard > li { counter-increment: step; padding: 0.5rem 0 0.75rem 2.5rem; position: relative; border-bottom: 1px dashed #eee; }
.wizard > li:last-child { border-bottom: 0; }
.wizard > li::before { content: counter(step); position: absolute; left: 0; top: 0.4rem; width: 1.75rem; height: 1.75rem; line-height: 1.75rem; text-align: center; background: #1a1a1a; color: #fff; border-radius: 50%; font-weight: 600; font-size: 0.85rem; }
.wizard > li.done::before { background: #114a2b; content: "✓"; }
.wizard h3 { margin: 0.25rem 0 0.5rem; }
.wizard pre { background: #f4f4f4; padding: 0.5rem 0.75rem; border-radius: 4px; overflow-x: auto; font-size: 0.85rem; }
.wizard code.copy { background: #f4f4f4; padding: 0.1rem 0.4rem; border-radius: 3px; user-select: all; }
.checklist { padding-left: 1.25rem; }
.checklist li { margin: 0.25rem 0; }
.prereqs { background: #fafafa; border: 1px solid #eee; border-radius: 6px; padding: 0.5rem 1rem; margin: 0 0 1.5rem; }
.prereqs h2 { margin: 0.5rem 0; font-size: 1rem; }
form label { display: block; margin: 0.75rem 0; }
form label input { display: block; width: 100%; padding: 0.5rem; border: 1px solid #ccc; border-radius: 4px; }
form button { padding: 0.5rem 1rem; border: 0; border-radius: 4px; background: #1a1a1a; color: #fff; cursor: pointer; }
.error { color: #b00020; background: #fdeaea; padding: 0.5rem 0.75rem; border-radius: 4px; }
.flash { color: #114a2b; background: #e7f4ec; padding: 0.5rem 0.75rem; border-radius: 4px; }
