/* Production plan screen — rebuilt to match the SDOS design handoff
   (Production page, handoff lines 1685-1816). Colors use theme tokens so
   dark mode keeps working; all classes are .prod- namespaced. */
@layer screens {
  /* page scroll column */
  .prod-page {
    display: flex; flex-direction: column; gap: 14px;
    padding: 2px 0 16px;
  }

  /* top chip / control row */
  .prod-chiprow { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
  .prod-spacer { flex: 1; }

  .prod-chip-date {
    border-radius: 999px; padding: 7px 14px; font-size: 13px; font-weight: 700;
    background: var(--primary); color: #fff;
  }
  .prod-chip-flat {
    border-radius: 999px; padding: 7px 13px; font-size: 12.5px; font-weight: 600;
    background: var(--surface); border: 1px solid var(--line); color: var(--text-2);
  }
  .prod-chip-shift {
    border-radius: 999px; padding: 7px 13px; font-size: 12.5px; font-weight: 600;
    background: var(--st-planned-bg); color: var(--st-planned-fg);
  }

  .prod-rawbtn {
    border: 1px solid var(--line-strong); cursor: pointer;
    background: var(--surface-2); color: var(--text-2);
    border-radius: 9px; padding: 8px 13px; font-size: 13px; font-weight: 600;
    text-decoration: none; display: inline-block;
  }
  .prod-rawbtn:hover { background: var(--surface-3); text-decoration: none; }
  .prod-raw {
    margin: 0; white-space: pre-wrap; word-break: break-word;
    font-family: var(--font-mono); font-size: 12.5px; line-height: 1.75;
    color: var(--text-2); background: var(--surface-2);
    border: 1px solid var(--line); border-radius: 10px; padding: 13px 15px;
  }

  /* staff strips */
  .prod-staffstrip { display: flex; gap: 10px; flex-wrap: wrap; }
  .prod-staffbox {
    display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 11px; padding: 9px 13px;
  }
  .prod-eyebrow {
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--muted); margin-right: 3px;
  }
  .prod-staffchip {
    border-radius: 6px; padding: 2.5px 9px; font-size: 12px; font-weight: 600;
    background: var(--surface-3); color: var(--text-2);
  }

  /* shortage / gap row */
  .prod-gaprow { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
  .prod-gaphead {
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--danger-fg);
  }
  .prod-gapchip {
    border-radius: 7px; padding: 4px 11px; font-size: 12px; font-weight: 700;
    background: var(--danger-bg); color: var(--danger-fg);
  }

  /* three-column flow */
  .prod-flow { display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-start; }
  .prod-arrow {
    align-self: center; color: var(--muted); font-size: 20px; font-weight: 700; padding: 0 2px;
  }

  .prod-col {
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 13px; overflow: hidden;
  }
  .prod-col-blow  { flex: 1 1 320px; }
  .prod-col-label { flex: 1.1 1 330px; }
  .prod-col-water { flex: 1.4 1 380px; }

  .prod-colhead {
    display: flex; align-items: center; gap: 8px; padding: 11px 14px;
    background: var(--surface-2); border-bottom: 1px solid var(--line);
  }
  .prod-coltitle { font-size: 13.5px; font-weight: 700; color: var(--text); }
  .prod-coltotal {
    font-size: 12px; font-weight: 700; font-family: var(--font-mono); color: var(--text-2);
  }

  .prod-subhead {
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--muted); padding: 8px 0 4px;
  }
  .prod-subhead-warn { color: var(--warn-fg); }

  /* blow column grid */
  .prod-blow-headrow {
    display: grid; grid-template-columns: 1fr 52px 64px 80px; gap: 6px;
    padding: 7px 14px; font-size: 11px; font-weight: 700; color: var(--muted);
    border-bottom: 1px solid var(--line);
  }
  .prod-blow-row {
    display: grid; grid-template-columns: 1fr 52px 64px 80px; gap: 6px;
    padding: 8px 14px; font-size: 13px; align-items: center;
    border-bottom: 1px solid var(--line);
  }
  .prod-machine {
    border-radius: 6px; padding: 1.5px 7px; font-size: 11px; font-weight: 700;
    background: var(--primary-soft); color: var(--primary);
  }

  /* label/sort column */
  .prod-labelbody { padding: 4px 14px 10px; }
  .prod-label-row {
    display: grid; grid-template-columns: 1fr 52px 80px; gap: 6px;
    padding: 7px 0; font-size: 13px; align-items: baseline;
    border-bottom: 1px solid var(--line);
  }
  .prod-shrink-row {
    display: grid; grid-template-columns: 1fr 52px 80px; gap: 6px;
    padding: 7px 8px; font-size: 13px; align-items: baseline;
    background: var(--warn-bg); border: 1px solid var(--warn); border-radius: 8px;
  }

  /* water column */
  .prod-waterbody { padding: 4px 14px 10px; }
  .prod-water-row {
    display: flex; flex-direction: column; gap: 5px; padding: 9px 0;
    border-bottom: 1px solid var(--line);
  }
  .prod-water-top { display: flex; gap: 8px; align-items: baseline; }
  .prod-water-tags { display: flex; gap: 5px; flex-wrap: wrap; }
  .prod-tag-room {
    border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 700;
    background: var(--st-planned-bg); color: var(--st-planned-fg);
  }
  .prod-tag-pack {
    border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 600;
    background: var(--surface-3); color: var(--text-2);
  }
  .prod-tag-ok {
    border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 700;
    background: var(--ok-bg); color: var(--ok-fg);
  }
  .prod-tag-wait {
    border-radius: 6px; padding: 2px 8px; font-size: 11px; font-weight: 700;
    background: var(--warn-bg); color: var(--warn-fg);
  }

  /* shared text utils */
  .prod-mono { font-family: var(--font-mono); }
  .prod-muted { color: var(--muted); }
  .prod-t2 { color: var(--text-2); }
  .prod-ellipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

  /* index list rows reuse the same visual language */
  .prod-list { display: flex; flex-direction: column; gap: 8px; }
  .prod-list-row {
    display: grid; grid-template-columns: 1fr 90px 90px 90px;
    gap: 12px; align-items: center;
    background: var(--surface); border: 1px solid var(--line);
    border-radius: 12px; padding: 12px 16px; text-decoration: none; color: var(--text);
  }
  .prod-list-row:hover { background: var(--surface-2); text-decoration: none; }
  .prod-list-head {
    display: grid; grid-template-columns: 1fr 90px 90px 90px;
    gap: 12px; padding: 4px 16px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--muted);
  }
  .prod-list-date { font-size: 14px; font-weight: 700; }
  .prod-list-num {
    text-align: right; font-family: var(--font-mono); font-size: 13.5px; font-weight: 700;
  }
  .prod-list-staff { font-size: 12px; color: var(--muted); margin-top: 2px; }
}
