/* Shell owns html/body; this file is loaded when the jobs view mounts
   inside #lf-view. Everything here should be scoped to the view — no
   global html/body/body-height rules. */

.jobs-root {
  display: flex;
  flex-direction: column;
  height: calc(100dvh - var(--lf-nav-h));
  overflow: hidden;
}
.jobs-root > .top-bar { flex-shrink: 0; }

.error { color: var(--lf-error); margin-top: 12px; }

.btn { border: 0; border-radius: 6px; padding: 10px 18px; font-size: 14px; cursor: pointer; font-weight: 600; }
.btn-primary { background: var(--lf-accent); color: var(--lf-accent-contrast); }
.btn-primary:hover { background: var(--lf-accent-hover); }
.btn-primary:disabled { background: var(--lf-btn-bg); color: var(--lf-text-dim); cursor: not-allowed; }
.btn-small { padding: 6px 12px; font-size: 12px; background: var(--lf-btn-bg); color: var(--lf-text); border: 1px solid var(--lf-border); }
.btn-small:hover { background: var(--lf-btn-hover); }

.top-bar { display: flex; justify-content: space-between; align-items: center; padding: 14px 24px; background: var(--lf-panel); border-bottom: 1px solid var(--lf-border); }
.top-bar h1 { margin: 0; font-size: 18px; color: var(--lf-text); }
.top-bar-right { display: flex; align-items: center; gap: 12px; }
.user-email { color: var(--lf-text-muted); font-size: 13px; }

.main-layout { display: grid; grid-template-columns: var(--lf-list-w) 1fr; flex: 1 1 auto; min-height: 0; }

.job-panel, .detail-panel { overflow-y: auto; }
.job-panel { border-right: 1px solid var(--lf-border); }
.panel-header { padding: 12px 16px; font-weight: 600; color: var(--lf-text-muted); text-transform: uppercase; font-size: 11px; letter-spacing: 0.5px; border-bottom: 1px solid var(--lf-border); }

.job-card { padding: 14px 16px; border-bottom: 1px solid var(--lf-border); cursor: pointer; }
.job-card:hover { background: var(--lf-panel-hover); }
.job-card.active { background: var(--lf-accent-bg); border-left: 3px solid var(--lf-accent); padding-left: 13px; }
.job-card-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.job-name { font-weight: 600; color: var(--lf-text); }
.job-card-meta { display: flex; gap: 10px; align-items: center; font-size: 12px; }

.toggle { position: relative; display: inline-block; width: 38px; height: 22px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.slider { position: absolute; inset: 0; background: var(--lf-border-strong); border-radius: 22px; transition: 0.2s; cursor: pointer; }
.slider:before { content: ""; position: absolute; height: 16px; width: 16px; left: 3px; bottom: 3px; background: #ffffff; border-radius: 50%; transition: 0.2s; }
.toggle input:checked + .slider { background: var(--lf-accent); }
.toggle input:checked + .slider:before { transform: translateX(16px); }

.detail-panel { padding: 24px; }
.detail-placeholder { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--lf-text-dim); }

.job-header h2 { margin-top: 0; margin-bottom: 6px; color: var(--lf-text); }
.kv-row { display: flex; gap: 16px; margin: 8px 0; font-size: 14px; align-items: center; }
.kv-key { color: var(--lf-text-muted); width: 100px; }

.interval-edit { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.interval-input { width: 72px; padding: 6px 8px; background: var(--lf-input-bg); border: 1px solid var(--lf-border); color: var(--lf-text); border-radius: 4px; font-size: 13px; }
.interval-unit { padding: 6px 8px; background: var(--lf-input-bg); border: 1px solid var(--lf-border); color: var(--lf-text); border-radius: 4px; font-size: 13px; }

.run-history-header { display: flex; align-items: center; justify-content: space-between; margin-top: 32px; margin-bottom: 12px; }
.run-history-header h2 { margin: 0; font-size: 16px; color: var(--lf-text); }

.run-row { background: var(--lf-panel); border: 1px solid var(--lf-border); border-radius: 6px; margin-bottom: 8px; }
.run-row summary { padding: 12px 16px; cursor: pointer; display: flex; gap: 16px; align-items: center; font-size: 13px; list-style: none; color: var(--lf-text); }
.run-row summary::-webkit-details-marker { display: none; }
.run-time { font-family: "JetBrains Mono", ui-monospace, monospace; }
.run-stats { margin-left: auto; color: var(--lf-text-muted); font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 12px; }
.run-body { padding: 0 16px 16px 16px; border-top: 1px solid var(--lf-border); }
.run-errors { margin: 12px 0; color: var(--lf-error); font-size: 13px; }
.run-errors ul { margin: 4px 0 0 16px; padding: 0; }
.run-logs { background: var(--lf-input-bg); padding: 12px; border-radius: 4px; font-size: 12px; white-space: pre-wrap; overflow-x: auto; max-height: 400px; color: var(--lf-text); border: 1px solid var(--lf-border); }

.badge { display: inline-block; padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; }
.badge-success { background: var(--lf-success-bg); color: var(--lf-success); border: 1px solid var(--lf-success-border); }
.badge-warn { background: var(--lf-warn-bg); color: var(--lf-warn); border: 1px solid var(--lf-warn-border); }
.badge-error { background: var(--lf-error-bg); color: var(--lf-error); border: 1px solid var(--lf-error-border); }
.badge-info { background: var(--lf-info-bg); color: var(--lf-info); border: 1px solid var(--lf-info-border); }
.badge-muted { background: var(--lf-btn-bg); color: var(--lf-text-muted); border: 1px solid var(--lf-border); }

.empty { padding: 32px 16px; text-align: center; color: var(--lf-text-dim); font-size: 13px; }
.run-footer { padding: 14px 16px; text-align: center; color: var(--lf-text-dim); font-size: 12px; }
.muted { color: var(--lf-text-muted); font-size: 12px; }

/* Back-to-list button lives in the detail panel and is only shown when the
   viewport falls into the mobile master-detail layout. */
.mobile-back {
  display: none;
  background: none; border: 0; color: var(--lf-accent);
  font-size: 14px; font-weight: 600; cursor: pointer;
  padding: 0 0 12px 0;
}
.mobile-back:hover { color: var(--lf-accent-hover); }

/* ─── Mobile: master-detail pattern ────────────────────────────────────── */
@media (max-width: 768px) {
  .top-bar { padding: 10px 14px; flex-wrap: wrap; gap: 8px; }
  .top-bar h1 { font-size: 15px; }
  .top-bar-right { gap: 8px; }
  .user-email { display: none; }

  .main-layout { grid-template-columns: 1fr; }
  .job-panel { border-right: 0; }
  .detail-panel { padding: 16px; }

  .jobs-root.job-selected .job-panel { display: none; }
  .jobs-root:not(.job-selected) .detail-panel { display: none; }

  .mobile-back { display: inline-block; }

  .kv-row { flex-wrap: wrap; gap: 6px 12px; }
  .kv-key { width: auto; min-width: 90px; }

  .run-row summary {
    flex-wrap: wrap; gap: 8px 12px; padding: 10px 14px;
  }
  .run-stats {
    margin-left: 0; width: 100%;
    font-size: 11px;
  }
  .run-logs { max-height: 260px; }

  .run-history-header { margin-top: 24px; }
}

