/* Live-demo input UI. Layers on top of reel_studio/styles.css (which styles body and
   the injected animatic player). Own components are prefixed .ld- so they never collide
   with the player's classes. No external fonts or resources. */

.ld { max-width: var(--maxw); margin: 0 auto; padding: 0 22px 24px; }

.ld-intro { padding: 22px 0 4px; }
.ld-intro h1 { margin: 0; font-size: 24px; }
.ld-intro p { color: var(--soft); margin: 8px 0 0; max-width: 70ch; }

.ld-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  box-shadow: var(--shadow); padding: 16px 18px; margin: 16px 0;
}

.ld-tabs { display: inline-flex; gap: 4px; background: #eef0f5; border-radius: 10px; padding: 3px; margin-bottom: 14px; }
.ld-tab {
  border: 0; background: transparent; font: inherit; font-weight: 600; color: var(--soft);
  padding: 8px 16px; border-radius: 8px; cursor: pointer;
}
.ld-tab.active { background: #fff; color: #3a2bb8; box-shadow: 0 1px 2px rgba(0, 0, 0, .08); }

.ld-pane { margin: 6px 0 4px; }
.ld-lbl { display: block; font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--faint); margin-bottom: 6px; }

.ld-textarea, .ld-input, .ld-select {
  width: 100%; font: inherit; color: var(--ink); background: #fbfbfe;
  border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px;
}
.ld-textarea { resize: vertical; line-height: 1.5; min-height: 120px; }
.ld-topic { min-height: 96px; }
.ld-hint { color: var(--soft); font-size: 12px; margin-top: 6px; }

.ld-file { font: inherit; margin: 2px 0 6px; }
.ld-filename { color: var(--soft); font-size: 13px; margin: 4px 0 8px; }
.ld-constraints { margin: 6px 0; padding-left: 18px; color: var(--soft); font-size: 13px; }
.ld-constraints li { margin: 3px 0; }
.ld-note { color: var(--faint); font-size: 12.5px; margin: 6px 0 0; }

.ld-rights { margin: 12px 0 4px; }
.ld-check { display: flex; gap: 9px; align-items: flex-start; font-size: 13px; color: var(--soft); cursor: pointer; }
.ld-check input { margin-top: 3px; }

.ld-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin: 14px 0 0; }
.ld-lbl-inline { font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--faint); }

.ld-seg { display: inline-flex; background: #eef0f5; border-radius: 10px; padding: 3px; }
.ld-seg button { border: 0; background: transparent; font: inherit; font-weight: 600;
  color: var(--soft); padding: 7px 14px; border-radius: 8px; cursor: pointer; }
.ld-seg button.active { background: #fff; color: #3a2bb8; box-shadow: 0 1px 2px rgba(0, 0, 0, .08); }

.ld-input { max-width: 280px; }

.ld-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 18px; }
.ld-btn {
  border: 0; background: linear-gradient(135deg, var(--accent), #8a6bff); color: #fff;
  font: inherit; font-weight: 700; padding: 11px 20px; border-radius: 10px; cursor: pointer;
}
.ld-btn:disabled { opacity: .45; cursor: not-allowed; }
.ld-cap { color: var(--faint); font-size: 12px; }

.ld-status { margin: 4px 0; }
.ld-status:empty { margin: 0; }

.ld-msg { border: 1px solid var(--line); border-radius: 12px; padding: 13px 16px; margin: 12px 0;
  box-shadow: var(--shadow); background: var(--panel); font-size: 14px; }
.ld-msg b { display: block; margin-bottom: 3px; }
.ld-msg.progress { color: var(--soft); }
.ld-msg.reject { background: #fff7f0; border-color: #f0d6b8; color: #7a4a12; }
.ld-msg.locked { background: #fff3f4; border-color: #f0c2c8; color: #842029; }
.ld-msg.degraded { background: #fffbe6; border-color: #f0e3a8; color: #7a5a12; }
.ld-msg.error { background: #fff3f4; border-color: #f0c2c8; color: #842029; }

.ld-foot { max-width: var(--maxw); margin: 0 auto; padding: 22px; color: var(--faint);
  font-size: 12.5px; border-top: 1px solid var(--line); }
.ld-foot div { margin: 4px 0; }
.ld-foot b { color: var(--soft); font-weight: 700; }

/* --- real-video render panel (v1) --- */
.ld-h2 { margin: 0 0 6px; font-size: 18px; }
.ld-video { display: block; width: 100%; max-width: 380px; margin: 14px auto 6px;
  border-radius: 14px; border: 1px solid var(--line); box-shadow: var(--shadow);
  background: #000; aspect-ratio: 9 / 16; }
.ld-videoout .ld-hint { text-align: center; }
