/* Direction 1 — Classic wizard. Centered card, top stepper. */

.wz-shell { min-height: 100vh; display: flex; flex-direction: column; background: var(--bg-app); }

/* a faint botanical wash at the top, behind the stepper */
.wz-shell::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; height: 280px;
  background: linear-gradient(180deg, rgba(204,235,194,0.45), transparent);
  pointer-events: none; z-index: 0;
}
.wz-shell > * { position: relative; z-index: 1; }

/* ----- top stepper ----- */
.wz-stepperbar { max-width: 980px; margin: 32px auto 24px; padding: 0 24px; }
.wz-stepper {
  display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
  gap: 4px; padding: 6px; background: white;
  border: 1px solid var(--border-1); border-radius: 999px;
  box-shadow: var(--shadow-1);
}
.wz-step {
  position: relative;
  padding: 10px 14px;
  display: flex; align-items: center; gap: 10px;
  border-radius: 999px;
  font-family: var(--font-body); font-size: 13px;
  color: var(--fg-3);
  cursor: default;
  transition: background 160ms, color 160ms;
  min-width: 0;
}
.wz-step__num {
  width: 24px; height: 24px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; font-size: 12.5px;
  background: var(--jfh-sea-shell); color: var(--fg-3);
  flex-shrink: 0;
}
.wz-step__label {
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.wz-step[data-state="done"] { color: var(--jfh-mountain-green); cursor: pointer; }
.wz-step[data-state="done"] .wz-step__num { background: var(--jfh-fern-green); color: var(--jfh-mountain-green); }
.wz-step[data-state="done"]:hover { background: var(--jfh-pistachio); }
.wz-step[data-state="active"] { background: var(--jfh-mountain-green); color: white; }
.wz-step[data-state="active"] .wz-step__num { background: var(--jfh-fern-green); color: var(--jfh-mountain-green); }
.wz-step[data-state="future"] .wz-step__num { background: var(--jfh-sea-shell); }

/* ----- generic step card ----- */
.wz-card {
  max-width: 880px;
  margin: 0 auto 96px;
  padding: 0 24px;
}
.wz-eyebrow {
  font-family: var(--font-display); font-weight: 600;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--jfh-cactus);
  margin-bottom: 8px;
}
.wz-h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: 36px; line-height: 1.05; letter-spacing: -0.02em;
  color: var(--jfh-mountain-green); margin: 0 0 10px;
}
.wz-lede {
  font-family: var(--font-body); font-size: 15.5px;
  color: var(--fg-3); margin: 0 0 28px; max-width: 56ch;
}

.wz-panel {
  background: white;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-1);
  padding: 32px;
}
.wz-panel + .wz-panel { margin-top: 16px; }
.wz-panel__h {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; color: var(--fg-1); margin: 0 0 18px;
  display: flex; align-items: baseline; gap: 10px;
  flex-wrap: wrap;
}
.wz-panel__h small { font-family: var(--font-body); font-weight: 500; color: var(--fg-3); font-size: 13px; }

.wz-footer {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 28px;
}
.wz-footer__left, .wz-footer__right { display: flex; gap: 10px; }
.wz-savehint { font-size: 13px; color: var(--fg-3); display: inline-flex; align-items: center; gap: 6px; }

/* ----- landing / PO entry ----- */
.wz-land-cards { display: grid; grid-template-columns: 1.5fr 1fr; gap: 16px; margin-top: 16px; }
.wz-land-cards .wz-panel { padding: 28px; }
.wz-land-cards .wz-panel--alt {
  background: var(--jfh-mountain-green);
  color: white;
  border-color: transparent;
}
.wz-land-cards .wz-panel--alt .wz-panel__h { color: white; }
.wz-land-cards .wz-panel--alt p { color: rgba(255,255,255,0.78); font-size: 14px; }
.wz-land-cards .wz-panel--alt .gi-input {
  background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); color: white;
}
.wz-land-cards .wz-panel--alt .gi-input::placeholder { color: rgba(255,255,255,0.45); }
.wz-land-cards .wz-panel--alt .gi-field__label { color: rgba(255,255,255,0.62); }
.wz-perks {
  display: grid; gap: 8px; margin-top: 18px;
  font-family: var(--font-body); font-size: 13.5px;
  color: rgba(255,255,255,0.85);
}
.wz-perks div { display: flex; align-items: center; gap: 10px; }

/* ----- PO summary banner ----- */
.wz-posum {
  display: grid; grid-template-columns: 2fr 3fr; gap: 24px;
  padding: 18px 22px;
  background: var(--jfh-mountain-green); color: white;
  border-radius: var(--radius-lg);
  margin-bottom: 16px;
  align-items: center;
}
.wz-posum__num {
  font-family: var(--font-mono); font-weight: 600;
  font-size: 28px; letter-spacing: 0.02em; color: white;
}
.wz-posum__sub { font-size: 13px; color: rgba(255,255,255,0.72); margin-top: 2px; }
.wz-posum__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.wz-posum__col { display: flex; flex-direction: column; gap: 2px; }
.wz-posum__col span:first-child { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.55); }
.wz-posum__col span:last-child { font-family: var(--font-body); font-size: 14px; color: white; font-weight: 500; }

/* ----- delivery type tiles ----- */
.wz-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.wz-tile {
  background: white; border: 1.5px solid var(--border-1); border-radius: var(--radius-lg);
  padding: 18px; cursor: pointer; display: flex; flex-direction: column; gap: 10px;
  transition: border-color 160ms, box-shadow 160ms, background 160ms;
  text-align: left;
}
.wz-tile:hover { border-color: var(--border-2); box-shadow: var(--shadow-1); }
.wz-tile[data-on="true"] { border-color: var(--jfh-mountain-green); background: var(--jfh-pistachio); }
.wz-tile__icon {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--jfh-pistachio); color: var(--jfh-mountain-green);
  display: inline-flex; align-items: center; justify-content: center;
}
.wz-tile[data-on="true"] .wz-tile__icon { background: var(--jfh-mountain-green); color: var(--jfh-fern-green); }
.wz-tile__label { font-family: var(--font-display); font-weight: 700; font-size: 15.5px; color: var(--fg-1); }
.wz-tile__sub { font-size: 12.5px; color: var(--fg-3); }

/* ----- PO lines table ----- */
.wz-lines-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--jfh-paper); border: 1px solid var(--border-1);
  border-radius: var(--radius-md); padding: 10px 14px; margin-bottom: 12px;
  gap: 12px;
}
.wz-lines-toolbar__left { display: flex; align-items: center; gap: 16px; }
.wz-lines-toolbar__right { display: flex; align-items: center; gap: 8px; }
.wz-lines-mode {
  display: inline-flex; background: white; border: 1px solid var(--border-2); border-radius: 999px; padding: 3px;
}
.wz-lines-mode button {
  background: transparent; border: 0; padding: 6px 12px;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  color: var(--fg-3); border-radius: 999px; cursor: pointer;
}
.wz-lines-mode button[data-on="true"] { background: var(--jfh-mountain-green); color: white; }

.wz-table { width: 100%; border-collapse: collapse; }
.wz-table thead th {
  text-align: left; padding: 12px 12px;
  font-family: var(--font-display); font-weight: 600; font-size: 11.5px;
  color: var(--fg-3); letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 1px solid var(--border-1);
  white-space: nowrap;
}
.wz-table tbody tr { border-bottom: 1px solid var(--border-1); }
.wz-table tbody tr:last-child { border-bottom: 0; }
.wz-table tbody td { padding: 14px 12px; vertical-align: middle; font-size: 14px; color: var(--fg-1); }
.wz-table tbody tr[data-off="true"] td { opacity: 0.5; }
.wz-table__sku { font-family: var(--font-mono); font-size: 12.5px; color: var(--fg-3); }
.wz-table__name { font-family: var(--font-display); font-weight: 600; font-size: 14.5px; color: var(--fg-1); }
.wz-table__pack { font-size: 12.5px; color: var(--fg-3); }
.wz-table__qty { display: flex; align-items: center; gap: 8px; }
.wz-table__qty-of { font-size: 12.5px; color: var(--fg-3); white-space: nowrap; }

/* ----- slot picker (grid) ----- */
.wz-daytabs { display: flex; gap: 8px; margin-bottom: 14px; }
.wz-daytab {
  flex: 1; background: white; border: 1px solid var(--border-2);
  border-radius: var(--radius-md); padding: 12px 14px; cursor: pointer;
  text-align: left;
  display: flex; flex-direction: column; gap: 2px;
  font-family: inherit;
}
.wz-daytab:hover { border-color: var(--jfh-mountain-green); }
.wz-daytab[data-on="true"] { background: var(--jfh-mountain-green); border-color: var(--jfh-mountain-green); color: white; }
.wz-daytab__dow { font-family: var(--font-display); font-weight: 600; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-3); }
.wz-daytab[data-on="true"] .wz-daytab__dow { color: rgba(255,255,255,0.65); }
.wz-daytab__date { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.wz-daytab__free { font-size: 12px; color: var(--fg-3); margin-top: 2px; }
.wz-daytab[data-on="true"] .wz-daytab__free { color: rgba(255,255,255,0.75); }

.wz-dock-picker { display: flex; gap: 8px; margin-bottom: 14px; }
.wz-dock-picker button {
  background: white; border: 1px solid var(--border-2);
  border-radius: 999px; padding: 8px 14px; cursor: pointer;
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  color: var(--fg-1);
}
.wz-dock-picker button[data-on="true"] { background: var(--jfh-mountain-green); color: white; border-color: var(--jfh-mountain-green); }

.wz-slots {
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px;
}
.wz-slot {
  font-family: var(--font-display); font-weight: 600; font-size: 13px;
  padding: 10px 4px; border-radius: var(--radius-sm);
  background: white; border: 1px solid var(--border-1); color: var(--fg-1);
  cursor: pointer; text-align: center;
  transition: background 140ms, border-color 140ms, color 140ms;
}
.wz-slot:hover:not([data-blocked="true"]) { background: var(--jfh-pistachio); border-color: var(--jfh-mountain-green); }
.wz-slot[data-blocked="true"] { background: var(--jfh-sea-shell); color: var(--jfh-stone-3); cursor: not-allowed; text-decoration: line-through; text-decoration-thickness: 1px; }
.wz-slot[data-on="true"] { background: var(--jfh-mountain-green); color: white; border-color: var(--jfh-mountain-green); }

/* slot picker — LIST variant */
.wz-slotlist { display: flex; flex-direction: column; gap: 4px; max-height: 360px; overflow-y: auto; padding-right: 4px; }
.wz-slotlist__row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; background: white; border: 1px solid var(--border-1);
  border-radius: var(--radius-md); cursor: pointer;
}
.wz-slotlist__row:hover:not([data-blocked="true"]) { background: var(--jfh-pistachio); }
.wz-slotlist__row[data-on="true"] { background: var(--jfh-mountain-green); color: white; border-color: var(--jfh-mountain-green); }
.wz-slotlist__row[data-blocked="true"] { opacity: 0.45; cursor: not-allowed; }
.wz-slotlist__time { font-family: var(--font-display); font-weight: 700; font-size: 15px; }
.wz-slotlist__meta { font-size: 12.5px; }

/* slot picker — CALENDAR variant */
.wz-cal { display: grid; grid-template-columns: 240px 1fr; gap: 24px; }
.wz-cal__calendar { background: var(--jfh-paper); border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: 16px; align-self: start; }
.wz-cal__monthhead { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; font-family: var(--font-display); font-weight: 700; font-size: 14px; }
.wz-cal__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; text-align: center; font-size: 12px; }
.wz-cal__dow { font-family: var(--font-display); font-size: 11px; color: var(--fg-3); padding: 4px 0; }
.wz-cal__day { font-family: var(--font-display); font-weight: 600; padding: 6px 0; border-radius: 6px; color: var(--fg-1); cursor: default; }
.wz-cal__day[data-muted="true"] { color: var(--jfh-stone-3); }
.wz-cal__day[data-avail="true"] { background: var(--jfh-pistachio); color: var(--jfh-mountain-green); cursor: pointer; }
.wz-cal__day[data-on="true"] { background: var(--jfh-mountain-green); color: white; }
.wz-cal__times { display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px; align-content: start; }

/* ----- file dropzone ----- */
.wz-drop {
  border: 1.5px dashed var(--border-2); border-radius: var(--radius-md);
  padding: 22px; text-align: center; background: var(--jfh-paper);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  color: var(--fg-3); font-size: 13.5px;
}
.wz-drop[data-has="true"] { border-style: solid; border-color: var(--jfh-fern-green); background: rgba(113,176,123,0.08); color: var(--jfh-mountain-green); }
.wz-drop strong { color: var(--jfh-mountain-green); font-family: var(--font-display); }

/* ----- review summary ----- */
.wz-review { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wz-review__block { background: var(--jfh-paper); border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: 16px; }
.wz-review__block h4 {
  font-family: var(--font-display); font-weight: 600; font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3);
  margin: 0 0 8px;
}
.wz-review__row { display: flex; justify-content: space-between; gap: 16px; padding: 4px 0; font-size: 14px; }
.wz-review__row span:first-child { color: var(--fg-3); }
.wz-review__row span:last-child { color: var(--fg-1); font-weight: 500; text-align: right; }

/* ----- confirmation ----- */
.wz-conf { max-width: 720px; margin: 64px auto 96px; padding: 0 24px; text-align: center; }
.wz-conf__tick {
  width: 88px; height: 88px; margin: 0 auto 16px;
  background: var(--jfh-fern-green); color: var(--jfh-mountain-green);
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 12px rgba(113,176,123,0.18);
}
.wz-conf__h { font-family: var(--font-display); font-weight: 800; font-size: 44px; color: var(--jfh-mountain-green); margin: 12px 0 8px; letter-spacing: -0.02em; }
.wz-conf__p { font-size: 16px; color: var(--fg-3); margin: 0 auto 28px; max-width: 50ch; }
.wz-conf__ref {
  display: inline-flex; flex-direction: column; align-items: center;
  background: white; border: 1.5px dashed var(--jfh-mountain-green);
  padding: 20px 28px; border-radius: var(--radius-md);
  margin-bottom: 28px;
}
.wz-conf__ref span:first-child { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-3); font-family: var(--font-display); font-weight: 600; }
.wz-conf__ref span:last-child { font-family: var(--font-mono); font-size: 30px; font-weight: 700; color: var(--jfh-mountain-green); margin-top: 6px; letter-spacing: 0.04em; }
.wz-conf__actions { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }

.wz-conf__detail { background: white; border: 1px solid var(--border-1); border-radius: var(--radius-lg); padding: 24px; margin-top: 32px; text-align: left; }

/* compact density toggle (applied at .wz-shell.gi--compact) */
.gi--compact .wz-panel { padding: 22px; }
.gi--compact .wz-card { padding-bottom: 24px; }
.gi--compact .wz-table tbody td { padding: 10px 12px; }
.gi--compact .wz-h1 { font-size: 28px; }
.gi--compact .wz-tile { padding: 14px; }
