/* ============================================================
   Portal-specific layer — built on UIPRO-CL tokens only.
   No hardcoded colours/spacing: everything references --uip-*.
   ============================================================ */

/* ---- step header (numbered) ---- */
.step-head{display:flex;align-items:center;gap:var(--uip-s3);margin-bottom:var(--uip-s5)}
.step-num{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  background:var(--uip-brand);color:var(--uip-brand-fg);
  display:grid;place-items:center;font-size:12px;font-weight:600;
}
.step-head.is-done .step-num{background:var(--uip-favourable)}
.step-title{font-weight:600;font-size:16px;letter-spacing:-0.01em}
.step-sub{font-size:12px;color:var(--uip-fg-muted);margin-top:1px}

.card-locked{opacity:.5;pointer-events:none;filter:saturate(.4)}

/* ---- forms ---- */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:0.08em;color:var(--uip-fg-muted)}
.input{
  font:inherit;font-size:14px;
  background:var(--uip-surface);color:var(--uip-fg);
  border:1px solid var(--uip-border);border-radius:var(--uip-r);
  padding:10px 12px;width:100%;
  transition:border-color var(--uip-dur) var(--uip-ease-out), box-shadow var(--uip-dur) var(--uip-ease-out);
}
.input::placeholder{color:var(--uip-fg-subtle)}
.input:focus{outline:none;border-color:var(--uip-brand);box-shadow:0 0 0 3px var(--uip-brand-soft)}

/* ---- buttons ---- */
.btn{
  font:inherit;font-size:13px;font-weight:500;
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 18px;border-radius:var(--uip-r);
  border:1px solid var(--uip-border);background:var(--uip-surface);color:var(--uip-fg);
  cursor:pointer;text-decoration:none;
  transition:background var(--uip-dur) var(--uip-ease-out), border-color var(--uip-dur) var(--uip-ease-out), transform var(--uip-dur-fast) var(--uip-ease-out);
}
.btn:hover{border-color:var(--uip-border-strong)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--uip-brand);border-color:var(--uip-brand);color:var(--uip-brand-fg)}
.btn-primary:hover{background:var(--uip-brand-tint);border-color:var(--uip-brand-tint)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn[disabled]{opacity:.45;cursor:not-allowed}
.btn-ghost{background:transparent}

.status{font-size:12.5px;color:var(--uip-fg-muted)}
.status.ok{color:var(--uip-favourable)} .status.err{color:var(--uip-adverse)} .status.busy{color:var(--uip-brand)}

/* ---- period picker ---- */
.period-wrap{display:grid;grid-template-columns:auto 1fr;gap:var(--uip-s6);align-items:start}
@media(max-width:760px){.period-wrap{grid-template-columns:1fr}}
.year-step{display:inline-flex;align-items:center;gap:var(--uip-s2)}
.year-step button{
  width:32px;height:32px;border-radius:var(--uip-r);border:1px solid var(--uip-border);
  background:var(--uip-surface);font-size:16px;color:var(--uip-fg-muted);cursor:pointer;
  display:grid;place-items:center;transition:border-color var(--uip-dur) var(--uip-ease-out)}
.year-step button:hover{border-color:var(--uip-brand);color:var(--uip-brand)}
.year-val{font-family:var(--uip-font-mono);font-size:22px;font-weight:500;min-width:74px;text-align:center}

.month-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
@media(max-width:520px){.month-grid{grid-template-columns:repeat(4,1fr)}}
.month-cell{
  font:inherit;font-size:13px;font-weight:500;
  padding:9px 0;border-radius:var(--uip-r);
  border:1px solid var(--uip-border);background:var(--uip-surface);color:var(--uip-fg-muted);
  cursor:pointer;text-align:center;
  transition:all var(--uip-dur) var(--uip-ease-out)}
.month-cell:hover{border-color:var(--uip-border-strong);color:var(--uip-fg)}
.month-cell.is-active{background:var(--uip-brand);border-color:var(--uip-brand);color:var(--uip-brand-fg)}
.month-cell.is-fynd{position:relative}
.month-cell.is-fynd::after{content:"";position:absolute;top:5px;right:6px;width:4px;height:4px;border-radius:50%;background:var(--uip-warning)}

.quick-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:var(--uip-s3)}
.quick-chip{
  font-size:11.5px;font-weight:500;padding:5px 11px;border-radius:999px;cursor:pointer;
  background:var(--uip-surface-2);border:1px solid transparent;color:var(--uip-fg-muted);
  transition:all var(--uip-dur) var(--uip-ease-out)}
.quick-chip:hover{border-color:var(--uip-brand);color:var(--uip-brand)}

.period-resolved{
  margin-top:var(--uip-s4);padding:var(--uip-s3) var(--uip-s4);
  background:var(--uip-brand-soft);border-radius:var(--uip-r);
  font-size:12.5px;color:var(--uip-brand);line-height:1.5}
.period-resolved b{font-weight:600}

/* ---- report cards ---- */
.reports-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--uip-s3);margin-bottom:var(--uip-s4)}
.report-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(max-width:760px){.report-grid{grid-template-columns:1fr}}
.report-card{
  position:relative;display:flex;gap:var(--uip-s3);align-items:flex-start;
  padding:var(--uip-s4);border:1px solid var(--uip-border);border-radius:var(--uip-r-lg);
  background:var(--uip-surface);cursor:pointer;
  transition:border-color var(--uip-dur) var(--uip-ease-out), background var(--uip-dur) var(--uip-ease-out), transform var(--uip-dur-fast) var(--uip-ease-out)}
.report-card:hover{border-color:var(--uip-border-strong)}
.report-card.is-selected{border-color:var(--uip-brand);background:var(--uip-brand-soft)}
.report-card.is-disabled{opacity:.55;cursor:not-allowed;background:var(--uip-surface-2)}
.report-check{
  width:20px;height:20px;border-radius:6px;flex-shrink:0;margin-top:1px;
  border:1.5px solid var(--uip-border-strong);background:var(--uip-surface);
  display:grid;place-items:center;color:transparent;font-size:12px;
  transition:all var(--uip-dur) var(--uip-ease-out)}
.report-card.is-selected .report-check{background:var(--uip-brand);border-color:var(--uip-brand);color:var(--uip-brand-fg)}
.report-name{font-size:13.5px;font-weight:600;letter-spacing:-0.01em}
.report-note{font-size:11.5px;color:var(--uip-fg-muted);margin-top:3px;line-height:1.45}
.report-badge{
  margin-left:auto;align-self:flex-start;font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:0.06em;padding:2px 7px;border-radius:999px}
.report-badge.ready{background:var(--uip-favourable-soft);color:var(--uip-favourable)}
.report-badge.pending{background:var(--uip-warning-soft);color:var(--uip-warning)}

/* ---- run / log ---- */
.log{
  font-family:var(--uip-font-mono);font-size:12px;line-height:1.65;
  background:var(--uip-fg);color:#E7E5DF;
  border-radius:var(--uip-r-lg);padding:var(--uip-s4) var(--uip-s5);
  min-height:160px;max-height:340px;overflow:auto;white-space:pre-wrap;
  border:1px solid var(--uip-border)}
.log:empty::before{content:"Waiting to start…";color:var(--uip-fg-subtle)}

.result-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--uip-s4)}
.downloads{margin-top:var(--uip-s5);display:flex;flex-direction:column;gap:var(--uip-s3)}
.file-list{display:flex;flex-direction:column;gap:6px}
.file-list a{
  display:inline-flex;align-items:center;gap:8px;font-size:13px;
  color:var(--uip-brand);text-decoration:none;font-family:var(--uip-font-mono)}
.file-list a:hover{text-decoration:underline}

/* ---- spinner ---- */
.spin{width:13px;height:13px;border-radius:50%;border:2px solid var(--uip-brand-soft);
  border-top-color:var(--uip-brand);display:inline-block;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.hidden{display:none!important}
